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1.9 INTRODUCTION 


The ACB-55988 disk controller provides an intelligent interface 
from an ANSI X3T9.2 SCSI host interface to four ST586 compatible 
Gisk drives. 


are! SCOPE 

This manual contains all of the information necessary to quickly 
install and operate the ACB-5598 with an SCSI compatible Host 
Adapter and up to four ST5@6 disk drives. 


Liz REFERENCE DOCUMENTS 


fe) ANSI X3T9.2 Small Computer System Interface Specification 
Ls3 ACB-550@ FEATURES 
fe) The ACB-5588 supports four ST5@6 hard- and soft-sectored 


drives. 


fe) The ACB-5588 supports a fully arbitrating SCSI system with up 
to seven other controllers or hosts sharing the SCSI bus. 


O The ACB-5580@ provides maximum SCSI bus throughput by 
supporting bus disconnection and reconnection for explicit 
and implied seeks. 


e) The ACB-5508 offers complete device independence by auto 
configuring to any size formatted drive. By storing drive 
parameters on the drive at format time, the need for host 
initialization of the controller for various drive types is 
eliminated. 


fe) The ACB-5508 may handle defects on a sector level by allowing 
the host to request that spare sectors be reserved on a 
cylinder basis. This provides formatted disks with constant 
data capacity and allows cylinder level formatting. 


fe) The ACB-5590@8, utilizing a 2K dual-ported buffer, eliminates 
the need for sector interleaving. This allows the host to 
read a track of data in a single revolution. 


fe) The ACB-5598 allows the host to reserve an entire logical 


unit, or particular extents on a logical unit, limiting or 
prohibiting data access by other hosts on the SCSI bus. 
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o °§6©6r The: ACB-5598 reduces selection overhead by allowing the host 
to link commands. Once a command is completed, the con- 
troller will immediately request and execute the next linked 
command. 


fe) The ACB-5508 reduces system overhead by queuing commands to 
the controller from different hosts. As commands are com- 
pleted, the next queued command will be executed. 


fe) The ACB-55@08 provides great operating system flexibility by 
offering sector lengths of 256, 512, or 1024 bytes. The 
sector length is programmed at format time. 


fe) The ACB-5588 supports direct and relative addressing of 
logical blocks. 


fe) The ACB-55@0@ guarantees excellent data integrity by utilizing 
a 32-bit error correction code on both the data and I.D. 
fields, SCSI bus parity checking and generation, and data 
buffer parity checking. 
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BLOCK LAYOUT 


1.4 


The component layout of the ACB-55@0 is shown in Figure 1-l. 
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NOTE: REVISION CHANGES IN THE BOARD 
COULD AFFECT THE PHYSICAL LOCATION OF 
THE COMPONENTS. 


Figure l-1l 


ACB-5588 Board Layout . 
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1.5 PRODUCT SPECIFICATION 
1.5.1 PHYSICAL DIMENSIONS 
Lengths: 8.76 inches 


Width: 5.75 inches 
Height: -8 inches 





1.5.2 POWER REQUIREMENTS 





Voltage Tolerance Current Ripple 
(volts) (Units) (max amps) (volts, RMS) 
+5 4.75 to 5.25 LS ~150 
+12 +18.8 to +13 0.300 158 


Li Dals ENVIRONMENTAL REQUIREMENTS 








Operating Storage 
Temperature (F/C): 32/8 to 131/55 ~49/-48 to 167/75 
Humidity: 18% to 95% 19% to 95% 
Altitude (ft.): | Sea Level to 10,808 Sea Level to 298,800 


Exhaust air flow may be required to keep the air on both sides of 
the board at or below the maximum operating temperature if ade- 
quate convective ventilation is not available. 


1.6 QUALITY ASSURANCE 


The ACB-5508 has been processed through Adaptec's extensive 
quality control procedure. All Adaptec custom ICs have been 
fully tested at temperature and voltage margins. All boards have 
been fabricated and assembled under close quality inspection. 
All boards have passed complete incircuit test procedures, have 
endured burn-in testing, and have been fully functionally tested. 
Adaptec should be notified immediately of any deviations from our 
high standard of quality. 
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2.0 THEORY OF OPERATION 


RED ete AAR Cone er AS AAR rE TEA es 





The ACB-55808 provides a powerful mechanism for connecting up to 
four ST506 compatible disk drives to a host computer via the 
Small Computer Systems Interface (SCSI). The SCSI provides a 
powerful general purpose device-independent connection usable by 
a wide range of computing systems. 


The ACB-558@ provides all of the data separation circuitry 
required to convert 5 Mb/sec NRZ to MFM encoded data. Adaptec's 
AIC-258 encode/decode chip designed with a discrete VCO circuit 
control write precompensation, addresses mark detect and data 
separation functions. 


The ACB-558@8 provides all required formatting and data 
synchronizing functions for ST586 compatible disk drives. The 
formatting function, data serializing/deserializing and ECC 
checking are provided by Adaptec's proprietary sequencer chip, 
the AIC-@190. 


The ACB-55808 provides up to 2K bytes of dual-ported buffering to 
allow high performance data access even if the attached host 
system can only accept data at very low rates. Adaptec's AIC-380 
buffer controller provides full dual porting for the buffer 
memory. 


The data transfer path is fully checked, using ECC and buffer 
parity checking to assure data integrity. Data integrity is not 
compromised by the unchecked control microprocessor. 


All low-speed control operations are managed by a powerful 8-bit 
Microprocessor executing instructions from a 16K read-only con- 
trol memory. The large control memory allows the implementation 
of several optional functions as well as a diagnostic self-tst 
capability. 


The formatting process stores device dependent parameter informa- 
tion on the attached disk drives. When the ACB-5598 is powered 
up, it automatically configures all internal tables from the 
stored parameters so that no drive configuration commands are 
required from the host system. 


Figure 2-1 shows the ACB-5508 block diagram, and Figure 2-2 
shows a flow chart of the ACB-55@9 microcode structure. 
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Figure 2-1. ACB-558@ Block Diagram 
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Power Up ----> Power Up Diagnostics ----> IDLE, polling <-- 
Reset “Hard and Reset host selection or 
seek complete 


SCSI Reset----> Get Off SCSI bus----- * 
Soft If working, sets up Host Selection 
for command retry Checking <----- 
Command Pre- 
Processing 

Shared / | 

Sub- | SEEK | READ WRITE FORMAT READ BUF. OTHERS 

routines\ | | | | | | 


Normal exit Error exit 


Figure 2-2. ACB-5500 Microcode Structure 


eek SYSTEM CONFIGURATION 
The ACB-550@ supports systems with a wide range of complexity. 


Figure 2-3 shows three SCSI configurations supported by the ACB- 
5506. 
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Figure 2-3. Typical SCSI Configurations 
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3.9 INSTALLATION 





The ACB-5508 is a self-contained circuit board. All logical and 
electronic functions required for its normal operation are 
contained on the circuit board. The ACB-5508 is simple to 
install, operate, and maintain. 


3.1 UNPACKING 


The ACB-5508 is shipped in a protective carton with shock 
absorbing material and static protecting material completely 
surrounding the card. The carton should be examined for external 
damage as it is opened. The cards were physically inspected when 
packed. Any mechanical damage to the cards should be reported to 
the shipper and to Adaptec as soon as possible. 


CAUTION 


All circuit boards containing VLSI circuitry have some 
sensitivity to electro-static discharge. The ACB-5588 is no 
exception. Proper handling precautions, including personnel 
grounding and work surface grounding, should be taken to prevent 
circuit stress which can cause premature circuit failure. 


3.2 PREPARATION OF INSTALLATION AREA 

The ACB-5508 is generally designed into the host system or the 
peripheral disk system. Proper attention should be given to the 
location of ACB-5508 so that the necessary ventilation, installa- 
tion clearances, and cabling paths are provided. 


The power output is low enough so that convective ventilation 
will be sufficient if the air and surrounding surfaces are ata 
temperature of 55 degrees Centigrade or less. If this 
requirement cannot be met by the system enclosure in its worst 
case environment, then the system enclosure must provide for 
appropriate ventilation and cooling. 


Care should be taken to support the card mechanically. Any 
appropriate combination of the 8 mounting holes provided can be 


used, depending on the forces to which the system will be sub- 
jected. No conductive material should come in contact with the 
ACB-55@0. 
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Installation clearances, both for the ACB-5508 and the selected 
power and signal cabling configuration, should be sufficient to 
optimize system cost, manufacturability, and maintainability. 


The ACB-5508 emits a small amount of radio-frequency signals. 
Extremely sensitive components, such as high band-width analog 
sensors, should be properly shielded from the ACB-55909. Normal 
case construction is sufficient to shield the ACB-5509 as 
required by the FCC. If FCC compliance is required and the SCSI 
leaves the box in which the ACB-55@0 is installed, the high 
frequency signals generated by normal SCSI operation may require 
connector and cable shielding. | 


The ACB-55@@ and all other partially shielded electronic devices 
are sensitive to high power high frequency electrical or magnetic 
sources. The ACB-5508 should be protected from such sources 
while it is operating. In particular, unshielded switching power 
supplies should be physically isolated from all electronic boards 
and their interconnecting cables. External noise sources, such 
as welding machines and radio transmitters, should be similarly 
isolated from electronic systems. Cable and connector shielding 
may be required in some environments. 


An appropriate power source must be provided. Care should be 
taken to prevent ground loops and other power disturbances. 


Proper programming support must be provided to generate the 
required command sequences. Additional program support must be 
provided to manage the SCSI protocols. Any system supporting the 
ACB-46@8 will also support the ACB-5509. Use of the advanced 
performance oriented functions will require a more powerful SCSI 
host adapter that supports disconnect/reconnect, command linking, 
and arbitration. Use of the advanced command functions requires 
expanded software support. Adaptec's host adapters will provide 
the required SCSI protocol services, but must receive the com- 
mands to be executed from appropriate system software. Many 
other SCSI systems are also available. 


3.3 INSTALLATION 


The following steps are required for installation of the ACB-5509 
into a system properly designed to accept it. These steps are 
separate from any other testing and installation procedures 
required by other portions of the system, but can often be done 
in conjunction with those other installation steps. 


1) Inspect ACB-5588 for obvious physical damage before 
installing. 


2) Install proper jumpers (see Section 3.4) to enable the 
desired ACB-55@98 functions and to define the address of the 
ACB-55@@ on the SCSI Bus. 


3) Install ACB-5589 with appropriate mounting hardware. 
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4) Make the required cable connections to the ACB-5508. The 
cable connections are: 


J7 - Power cable 

J8 - SCSI cable 

J2, 33, J4, 33 - ST506 data cable (radial connections 
aS required) 

Jl - ST506 control cable. 


5) Install ST5@6 drives according to the manufacturer's direc- 
tions. The drives must have appropriate drive select address 
and bus terminators set. The last ST5@6 drive on the control 
cable daisy chain must be terminated. 


5) Power on the system and perform any power-on test procedures 
required by the system. 


7) Format the attached drives. (See Section 3.7.) 


Note: In a production environment, the drives may be option- 
ally formatted by a dedicated ACB-550@ manufacturing work 
station before installation. Since all parameters are stored 
on the drive by the formatting procedure, further formatting 
or parameter specification is not required after installa- 
tion. The ACB-55@08 will auto configure to the drive param- 
eters at power-on time. © 


8) Perform appropriate system test and verification procedures. 
Errors related to drive operation, ACB-5588 operation, SCSI 
operation, and certain installation errors will be indicated 
through the normal SCSI error presentation mechanism. 


3.4 CONFIGURING THE ACB-559@ 


The ACB-550@ has a number of options that must be selected by the 
installation of hardware jumpers located at position J6 on the 
controller. The function of each jumper pair is shown in Table 
3-1. The jumper header is designed to accommodate jumpers with 
optimum reliability, the jumper pairs may be wire-wrapped 
together. 
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Table 3-1. Configuration Jumpers 


A 7Tooy| sB “= SCSI Reset Option 
Cc 0 Oo D  = Raveeved 
E ° fe) F - Hard Sectored Lung 
G 0 oO H - Hard Sectored Lunl 
J rome) K - Reserved 
oO Diag - Diagnostic Mode 
0 07 Par - Parity Enable 
oO A4 - SCSI Address 2 
oe) A2 - SCSI Address 2 
oe) Al - SCSI Address 


3.4.1 SCSI RESET OPTION 


The installation of the A-B jumper will cause the ACB-55@8 to 
initiate a "Hard" reset in response to an SCSI bus reset. 
Without this jumper installed, a "Soft" reset will result. The 
effect of both a "Hard" and "Soft" reset are detailed in Section 
hele Sel 


3.4.2 HARD SECTORED/REMOVABLE DRIVES 


The installation of the E-F or G-H jumpers will indicate to the 
ACB-55@@ that a hard sectored drive is attached as logical Unit @ 
or 1 respectively. The presence of a jumper will cause the ACB- 
5598 to use the sector pulse input from the drive. The jumpers 
must only be installed if a hard sectored drive is attached. 
Hard sectored drives must either be logical unit @ or l. 


3.4.3 DIAGNOSTIC MODE 
The installation of the DIAG jumper will cause the ACB-55898 to 


continuously repeat a diagnostic self test. Appendix A details 
this self test. 
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3.4.4 PARITY ENABLE 


The installation of the PAR jumper will cause the ACB-559@ to 
check for bus out (data into the ACB-5598) parity errors. This 
jumper should only be installed if all SCSI devices communicating 
with the ACB-5588 generate SCSI data parity. The ACB-5500 will 
always generate parity on bus in data. 


3.4.5 SCSI BUS ADDRESS 


The installation of jumper A4, A2, and Al set the SCSI bus 
address for the ACB-5509. SCSI devices can have an address of @ 
to 7 but no two devices can have the same address. 


3.5 POWERING-ON THE ACB-5509 


Once the ACB-5588 is properly configured, the controller may be 
powered on. When power is supplied to the system, the controller 
will enter a power-up mode and wait for a maximum of 18 seconds 
for the drive to become ready. During the 18-second power-on 
sequence, the controller performs a self test and begins checking 
for drive @, 1, 2, and 3 to become ready. If the host sends a 
command requiring access to a drive before it has become ready 
(and before 18 seconds have elapsed) the controller will accept 
the command and continue to check for a ready status. Once the 
drive comes ready, the controller will then execute the command; 
if 18 seconds elapse, and the drive does not come ready, a DRIVE 
NOT READY (@4,,) error will result. The controller will then 
check for a ready status on the next command requiring access to 
that drive. 


Once a drive comes ready, the controller will recalibrate the 
head to track @. If the drive started at track 9, the controller 
will step the head off of track @ to confirm that the drive can 
seek and that the track @ signal was valid. With the drive's 
ability to seek confirmed, the controller then seeks back to 
track @. The drive actuator (if it can be seen) appears to make 
a short 'blip.' 


The controller then attempts to read from track 8, parameter 
information, which is written during formatting. If the drive is 
unformatted, or had been formatted by other than an Adaptec 
controller, the parameter information is not present. The 
controller then sets "blown format" to warn the user that the 
drive is unusable, the reset sequence is stopped and the 
controller is ready for a command. The drive must be formatted 
to allow a READ or WRITE access to disk data. 


If the drive is correctly formatted, the controller will seek the 
drive to the last cylinder and read the largest block address 
present. The parameter information and largest block addresses 
are saved by the ACB-55@@. 
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Once the last block address has been read, the controller will 
seek the drive back to track @, stopping several times in ‘zones' 
to read the devect counyt within each zone. This defect count is 
also saved in the controller to asllow it to better predict the 

location of a block on the disk for accurate seeking. . 


Once a drive is formatted, the host can determine the drive size 
(READ CAPACITY, 25,4, command) and self-configure without any 
driver software modification. This device independence provides 
a major advantage for host systems using true SCSI controllers 
over the SASI-like units that send parameters at a reset and with 
commands. 


3.6 COMMUNICATING WITH THE ACB-5580 
The SCSI bus is a simple bus to interface. However, a quick 
reading of the SCSI spec may leave you lost due to its extreme 
attention to detail. Also, some SASI-like controllers exist on 
the market which allow some deviation from the ANSI/SCSI 
protocol. The important point to remember in designing a drive 
routine is that once the controller is started by the host, THE 
CONTROLLER CONTROLS THE SCSI BUS. The controller drives the data 
direction line (I/0), the phase lines (C/D and MSG) and initiates 
data transfers (REQ). The host drive should make no assumptions 
about the bus phases or byte counts. In addition, the controllr 
can (and will) change phases betwen operations while going 
through intermediate phases. Thus, the phase lines (C/D and MSG) 
are only valid when the controller asserts REQ. Do not write 
your driver or allow your hardware to follow phases when REQ is 
not active or it may be 'fooled' by phase changes between REQ. 
Also, other controllers only support some 6-byte commands, thus 
some users have set up counters in their software to send a 6- 
byte command. Since the ACB-5508 controller supports 6 and 19- 
byte commands, the hardware/software should not count out the 
command bytes but rather should send command bytes as long as the 
controller requests them. Trust the controller; it 'knows' how 
many bytes it needs. 


The sequence of operations for a single command used in the 
simplest of SCSI applications would be: 


1) Select the controller onto the bus (wake it up). Be sure 
select remains asserted until the controller responds Busy. 


2) Send the ACB-55808 the appropriate command bytes until it 
changes phases (do not count bytes). If too many or too few 
bytes are REQuested, check for valid command op code and 
proper SCSI REQ/ACK timing. 


3) If required, send/receive data until phase changes (do not 
count bytes; controller will determine data direction). 


4) Receive (REQ/ACK cycle) 1 status byte and save for evaluation 
(See Section 4.5). 
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5) Receive (REQ/ACK cycle) 1 message byte (See Section 4.2). 


6) Check status byte. If Busy bit set, resend command; if 
Check bit set, send REQUEST SENSE (@3,,) command to get error. 


3.7 FORMATTING WITH THE ACB-5598@ 
A sample MODE SELECT command for a sesgaKEs ST412-type drive is 
described below: 


Step 1: MODE SELECT Command 


Drive Type: Seagate ST412: 
306 cylinders 
4 heads 
28 uS step rate 
Reduced write current at cylinder 256 
Write precompensation at cylinder 256 


Hex Description 
MODE SELECT Command 


15 OP Code (15,, ) for MODE SELECT 

B@ Formatting Fund 

OO Reserved 

04) Reserved 

16 Number of data bytes appended (16,,) 
BO Reserved 


Extent Descriptor List 


8G Reserved 

GO Reserved © 

88 Length of drive descriptor list 

8B Density code 

4) Reserved 

BB Reserved 

a4) Reserved 

GB High byte of block size to be formatted (256 bytes) 
1 Middle byte of block size to be formatted 

8G Low byte of block size to be formatted 


Drive Parameter List 


G1 Interface code (must be @1) 

G1 High byte of cylinder count 

G2 Hard sector drive or removable cartridge 

32 Low byte of cylinder count 

G4 Total number of heads 

1 High byte of reduced write current cylinder 
GO - Low byte of reduced write current cylinder 
G1 High byte of write precompensation cylinder 
8B Low byte of write precompensation cylinder 
GB Landing zone position (see STOP, 1B, command) 
G1 Head step rate (@2-12 us, @1=28us, @9=3Ms) 
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Note: Two additional bytes would be added for a hard- 
sectored or removable drive (See Section 6.14). 


After the MODE SELECT has been transferred to the controller and 
good completion status has been sent to the host, the drive may 
be formatted. 


Step 2: FORMAT UNIT 


Interleave of 1:1 

Fill data fields with E5y, 

1 defect at head 2, cylinder 11, 256 bytes from index 
2 space sectors per cylinder 


FORMAT UNIT command 


Hex Description 
04 Op code (94, for FORMAT UNIT command) 
1E Lun@ and indicate fill character and defect 
descriptor appended 
E5 Character to be filled in data fields 
OG High byte of interleave (must be @@) 
G1 Low byte of interleave 
OD Reserved 


FORMAT UNIT Data Block 


GG Format entire unit 

G2 Allocate 2 spare sectors per cylinder 
On) High byte of length of defect list 

G8 Low byte of length of defect list 

BB High byte of cylinder number of defect 
oa) Middle byte of cylinder number of defect 
8B Low byte of cylinder number of defect 
G2 Head number of defect 

5) High byte of defect bytes from index 
Et) Middle byte of defect bytes from index 
G1 Middle byte of defect bytes from index 
a) Low byte of defect bytes from index 


The same procedure can be used for formatting single cylinders. 
Section 6.4.2 contains details on changes required to the FORMAT 
UNIT command for cylinder level formatting. 


The ACB-5500 allows you to select the desired interleave factor 
with the FORMAT UNIT command. The interleave can range from zero 
to the number of blocks per track, minus 1. The number 
represents the number of physical blocks between consecutive 
logical block numbers, thus an interleave of 1 means that the 
sectors are consecutive. 
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The use of an interleave factor 1 allows a maximum transfer rate 
but will only be effective with a host adapter and system capable 
of very high transfer rates. On the other hand, the use of 
interleaving can maximize the storage capacity of your drive. 


Table 3-2 shows the number of formatted sectors per track for 


different block sizes and interleaves when using soft sectored 
drives. 


Table 3-2. Interleaved Sectors/Track 


SECTOR SIZE INTERLEAVE SECTORS/TRACK 
256 1 32 
256 >1 33 
512 1. 17 
512 >1 18 
1624 1 9 
1624 >1 9 
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4.0 SCSI INTERFACE DESCRIPTION 








EF A A AA SE 


This section briefly describes the SCSI protocol implemented by 
the Adaptec ACB-5588 controller. The SCSI protocols are 
described in detail in the ANSI X3T9.2 Small Computer System 
Interface Specification, version 14. 


4.1 GENERAL DESCRIPTION OF SCSI 

This system interface provides an efficient method of communica- 
tion between a maximum of 8 computers and peripheral I/O devices. 
The eight-port daisy-chained bus defined by the SCSI specifica- 
tion supports the following features: 


o Single or multiple host system 
o Multiple peripheral devices and device types 
o Multiple overlap of peripheral device operations 


o Bus contention resolution through arbitration on a prioritized 
basis 


Oo Asynchronous data transfer at up to 1.5 MBytes/sec. 
o Host-to-host communication. 


Communication on the bus is allowed between two bus ports ata 
time. A maximum of eight (8) bus ports are allowed. Each port 
is attached to an SCSI device (e.g., controller or host adapter). 


When two devices communicate with each other on the bus, one acts 
as an Initiator and the other acts as a Target. The Target 
(typically a controller) executes the operation. A device will 
usually have a fixed role as an Initiator or Target, but some 
devices may be able to assume either role. The ACB-5508 always 
assumes a Target role. 


An Initiator, or attached host adapter, may address up to four 
logical units on an ACB-5500. Each logical unit is a separate ST 
586 disk drive having the characteristics (i.e., capacity) with 
which it was formatted. The ACB-55098 manages them as independent 
units, keeping all necessary progress information for each 
device. 
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Access to the SCSI bus is handled through arbitration. The 
arbitrating SCSI device with the highest bus address is given 
priority. The Initiator selects a Target. The Target then 
manages all further communications, requesting commands from the 
Initiator, transferring the required data, and transmitting 
ending status. A Target may reselect an Initiator to complete a 
disconnected operation. 


Data transfers on the bus are asynchronous and follow a defined 
REQUEST/ACKNOWLEDGE protocol. One eight-bit byte of information 
may be transferred with each handshake. 


4.1.1 BUS SIGNALS 


The SCSI bus consists of 9 control signals and 9 data signals. 
These are described below: 


Seka bal BUSY (BSY) 


BSY is an "or-tied" signal which indicates that the bus is in 
use. ; : 


4.1.1.2 SELECT (SEL) 


SEL is an “or-tied" signal used by an Initiator to select a 
Target or by a Target to reselect an Initiator. 


4.1.1.3 CONTROL/DATA (C/D) 

C/D is a Target-driven signal to indicate whether CONTROL or DATA 
information is on the data bus. Assertion indicates CONTROL. 
Outbound control information is a eonmang while inbound control 
information is status. 

4.1.1.4 INPUT/OUTPUT (I/0) 

I/O is a Target-driven signal which controls the direction of 
data movement on the data bus relative to an Initiator. 
Assertion indicates INPUT to the Initiator. 

4.1.1.5 MESSAGE (MSG) 

MSG is a Target-driven signal indicating the MESSAGE phase. 
4.1.1.6 REQUEST (REQ) 


REQ is a Target-driven signal indicating a request for a REQ/ACK 
data transfer handshake. 


4.1.1.7 ACKNOWLEDGE (ACK) 


ACK is an Initiator-driven signal, in response to a target REQ, 
indicating the transfer of a byte to or from the ACB-5580 
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Peat 


4.1.1.8 ATTENTION (ATTN) 


ATTN is an Initiator-driven signal indicating the ATTENTION condi- 
tion. ATTNis a request from the Initiator to transmit a message 
to the ACB-550@. 


oe oe eg RESET (RST) 


RST is an “or-tied" signal indicating the RESET condition. The 
ACB-55@80 never initiates a RESET condition. 


4.1.1.16 DATA BUS (DB: 7-0, PARITY) 


Eight data bit signals, plus a parity bit signal, comprise the 
DATA BUS. DB(7) is the most significant bit and has the highest 
priority during arbitration. Significance and priority decrease 
with decreasing bit number with the least significant being 
DB(@). 


Each of the eight data signals DB(7) through DB(@) is uniquely 
assigned as a Target or Initiator bus address (i.e., DEVICE 
I.D.). The Device ID is set in an ACB-5588 by jumpers Al, A2, 
and A4. 


Data parity, DB(P), is odd. The ACB-550@ always generates 
correct bus parity for inbound transfers. A jumper is installed 
to enable the ACB-55@08 to check outbound parity for those systems 
that support parity. All Initiators must support parity if the 
ACB-55@8 parity check is enabled. 


4.1.2 BUS PHASES 

The bus has eight distinct operational phases and cannot be in 
more than one phase simultaneously. Detailed phase information 
and timing specifications are contained in the ANSI X3T9.2 SCSI 
Specification. 

-o BUS FREE 

Oo ARBITRATION 

Oo SELECTION 


Oo RESELECTION 


Oo COMMAND \ 
o DATA 
INFORMATION TRANSFER PHASES 
o STATUS 
© MESSAGE rf 
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4.1.2.1 BUS FREE PHASE 


The BUS FREE phase, indicating that the bus is available for use, 
is entered by the deassertion and passive release of all bus 
signals. Once the BUS FREE phase is detected, the active initia- 
tor must deassert and passively release all bus signals (within a 
BUS CLEAR DELAY) after deassertion of BSY. 


Devices sense BUS FREE when SEL and BSY are not asserted 
(simultaneously within a DESKEW DELAY of 45 Dene and the RESET 
condition is not active. 


4.1.2.2 ARBITRATION PHASE 


The ARBITRATION phase allows one SCSI device to gain control of 
the bus. Once a device that wants to arbitrate for the bus 
detects the BUS FREE phase, it waits a BUS FREE DELAY, 889 nsec, 
and then asserts BSY with its own I.D. bit on the Data Bus. (Data 
parity is not guaranteed valid during ARBITRATION.) 


After an ARBITRATION DELAY, the device examines the data bus. If 
a higher priority I.D. is on the bus or a select from another 
device is present, the device clears itself from arbitration by 
releasing the BSY and 1.D. signals. If the device determines 
that its own I.D. is the highest priority, it leaves BSY asserted 
and asserts SELECT. ARBITRATION is then complete. 


ee ee SELECTION PHASE 


During the SELECTION phase, the I/O signal is deasserted so that 
this phase can be distinguished from the RESELECTION phase. The 
ACB-55898 operates in both arbitrating and non-arbitrating sys- 
tems. In non-arbitrating systems, there may be only one Initia- 
tor. It may raise select with the Target I.D. asserted whenever 
the BUS FREE Phase is present. 


In arbitrating systems, the SELECTION phase is entered with both 

BSY and SEL asserted; the Initiator then waits a minimum of a 
Bus Clear Delay plus a Bus Settle Delay before driving the DATA 
bus with the Target I.D. and its own I.D. After two DESKEW 
DELAYS, the Initiator then releases BSY. If only one Initiator 
is installed, and no disconnection is supported, the Initiator 
need not provide its own I.D. 7 


On detecting the condition that Select and its own I.D. are 
asserted, and BSY and I/O are not asserted, the selected Target 
examines the DATA bus for the Initiator I.D. and responds by 
asserting BSY. . 
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After a minimum of two DESKEW DELAYS, 9@ nsec., (following the 
detection of BSY from the Target), the Initiator deasserts SEL 
and may change the DATA signals. 


The Initiator may "time out" the SELECTION phase by deasserting 
the I.D. bits on the bus. If, after a TIMEOUT DELAY, 2508 msec, 
BSY has not been asserted, one of the selection timeout proce- 
dures specified in the ANSI X379.2 SCSI specification will be 
followed. The ACB-5500 drives BSY within 258 microseconds of 
detecting SEL and its own I.D. If parity checking is enabled, 
Bus Out parity must be valid during the selection phase. 


4.1.2.4 RESELECTION PHASE 


If an Initiator supports reconnection, the ACB-55808 can release 
the SCSI bus for other activities while the disk devices are 
performing mechanical motions. The Initiator informs the ACB- 
5500 that it can support reconnection by transmitting the proper 
bits in the Identify MESSAGE OUT right after the Selection phase. 
The ACB-550@ will then disconnect at the proper times, first 
presenting a Save Pointers message and a Disconnect message to 
the Initiator. The Save Pointers message indicates to the 
Initiator that it must preserve all necessary information to 
later continue the operation when reconnect takes place. 


After successfully gaining control of the SCSI by winning arbi- 
tration, the Target has both BSY and SEL asserted. It then 
informs the Initiator that it desires reconnection by asserting 
the I/0 signal. The ACB-55@98 then drops BSY. The reselected 
Initiator then asserts BSY. When the ACB-5508@ sees the Initia- 
tor's BSY, it raises BSY and drops SEL, causing the Initiator to 
drop BSY, ending in the same state as it would be for a normal 
selection. The ACB-55@8 then informs the Initiator which device 
is being reconnected with an Identify MESSAGE IN. The Initiator 
then restores all the necessary state information to continue the 
Original operation. 


4.1.2.5 INFORMATION TRANSFER PHASES 


The COMMAND, DATA, STATUS and MESSAGE phases are all used to 
transfer data or control information through the SCSI _ bus. 


The C/D, I/0 and MSG signals are used to differentiate the 


various INFORMATION TRANSFER phases. Note that these signals are 
not meaningful until REQ has been asserted. See Table 4-1. 
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Table 4-1. Information Transfer Phases 











t SIGNAL DIRECTION OF 

MSG | C/D JO PHASE NAME INFORMATION XFER 
g g g DATA OUT | (INIT to ACB-55098) 
g g 1 DATA IN (ACB-550@8 to INIT) 
g ie G COMMAND (INIT to ACB-5509) 
g 1 1 STATUS (ACB-550@8 to INIT) 

1 4] g Reserved 

1: 4 Ll Reserved 
1 1 g MSG OUT (INIT to ACB-55G@) 
1 1 l MSG IN (ACB-55098 to INIT) 

NOTES: @ = SIGNAL DEASSERTION 
1 = SIGNAL ASSERTION 
INIT = INITIATOR 
ACB-550@ = TARGET 


The INFORMATION TRANSFER phases use the REQ/ACK handshake to 
control data transfer. Each REQ/ACK allows the transfer of one 
byte of data. The handshake starts with the Target asserting the 
REQ signal. The Initiator responds by asserting the ACK signal, 
indicating a byte transfer. The Target then deasserts the REQ 
signal and the Initiator responds by deasserting the ACK signal. 


With I/O signal asserted, data will be input to the Initiator 
from the ACB-550@. The ACB-5598 ensures that valid data is 
available on the bus (at the Initiator port) before the assertion 
of REQ at the Initiator port. The data remains valid until the 
assertion of ACK by the Initiator. The Initiator must ensure 
that data has been read from the bus before asserting ACK. The 
ACB-5508 compensates for cable skew and the skew of its own 
drivers. The ACB-5508 always guarantees good parity on inbound 
data transfers. 


With the I/O signal not asserted, data will be output from the 
Initiator to the ACB-5509. The Initiator must ensure valid data 
on the bus (at the Target port) before the assertion of ACK on 
the bus. The Initiator should compensate for cable skew and skew 
of its own drivers. Valid data must remain on the bus until the 


ACB-55088 deasserts REQ. The ACB-55898 will optionally check 
Parity on the outbound data transfers. 
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During each INFORMATION TRANSFER phase, the BSY line remains 
asserted, the SEL line remains deasserted, and the ACB-5589 will 
continuously envelop the REQ/ACK handshake(s) with the C/D, I/0 
and MSG signals in such a manner that these control signals are 
valid for at least a BUS SETTLE DELAY before the REQ of the first 
handshake and remain valid until the deassertion of ACK at the 
end of the last handshake. . 


4.1.2.5.1 COMMAND PHASE 


The COMMAND phase is used by the ACB-5588 to obtain Command 
Descriptor Blocks from the Initiator. 


The ACB-558@ asserts the C/D signal and deasserts the I/O and MSG 
signals during the REQ/ACK handshake(s) of this phase. 


4.1.2.5.2 DATA PHASES (DATA IN/DATA OUT) 
The DATA phase includes both the DATA IN phase and DATA OUT 
phase. 


The DATA IN phase is used by the ACB-5588 to input device data or 
state information to the Initiator. The ACB-5588 asserts the I/0 
signal and deasserts the C/D and MSG signals during the REQ/ACK 
handshake(s) of this phase. 


The DATA OUT phase is used by the ACB-550@ to obtain write data 
and control parameters from the Initiator. The ACB-5596 
deasserts the C/D, I/O and MSG Signals during the REQ/ACK hand- 
shake(s) of this phase. 


oe ey ere. STATUS PHASE 


The STATUS phase is used by the ACB-558@ to send status informa- 
tion to the Initiator. Controller status contains information 
relating to the completion of the last command executed. Section 
4.5 details the status information implemented in the ACB-559@. 


The Target asserts C/D and I/O and it deasserts the MSG signal 
during the REQ/ACK handshake(s) of this phase. 


4.1.2.5.4 MESSAGE PHASES (MESSAGE IN/MESSAGE OUT) 
The MESSAGE phase includes both MESSAGE IN and MESSAGE OUT 
phases. Section 4.2.2 details the messages information imple- 
mented in the ACB-55@9. 


The MESSAGE IN phase is used by the ACB-5598 to present a 


message to the Initiator. The ACB-5500 asserts C/D, I/O and MSG 
during the REQ/ACK handshake(s) of this phase. 
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The MESSAGE OUT phase is used by the ACB-5509@ to obtain a message 
from the Initiator. The ACB-5508 invokes this phase only in 
response to the ATTENTION condition from the Initiator. In 
response to the ATTENTION condition, the ACB-5580 asserts C/D and 
MSG and deasserts the I/O signal during the REQ/ACK handshake(s) 
of this phase. The Target handshakes byte(s) in this phase until 
the ATTN signal goes false. 


416266 SIGNAL RESTRICTIONS BETWEEN PHASES 
When the BUS is between phases, the following restrictions apply 
to the bus signals: 


o The BSY, SEL, REQ and ACK signals may not change. 
o The C/D, I/0, MSG and DATA signals may change. 


o The ATTN and RST signals may change as defined under the 
descriptions for the ATTENTION and RESET conditions. 


4.1.3 BUS CONDITIONS 


The bus has two asynchronous conditions: The ATTENTION condition 
and the RESET condition. These conditions cause certain BUS 
DEVICE actions and can alter the bus phase sequence. 


4.1.3.1 ATTENTION CONDITION 


ATTENTION allows the Initiator to signal the ACB-5500 of a wait- 
ing message. The ACB-55@08 may access the message by invoking a 
MESSAGE OUT phase. 


The Initiator creates the ATTENTION condition by asserting ATTN 
at any time except during the ARBITRATION and BUS FREE phase. 
The ACB-5588 responds when ready with the MESSAGE OUT phase. The 
Initiator keeps ATTN asserted if more than one byte is to be 
transferred. | 


The Initiator can only deassert the ATTN signal during the RESET 
condition, during a BUS FREE phase, or while the REQ signal is 
asserted and before the ACK signal is asserted during the last 
REQ/ACK handshake of a MESSAGE OUT phase. 


While the ATTN is asserted, the Initiator must continue to 


respond to the Target command or data transfers since the Target 
may not process the ATTN immediately. 
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4.1.3.2 RESET CONDITION 


The RESET condition, created by the assertion of RST, is used to 
immediately clear all devices from the bus and to reset these 
devices and their associated equipment. 


RESET can occur at any time and takes precedence over all other 
phases and conditions. Any device (whether active or not) can 
invoke the RESET condition. On RESET, all devices immediately 
(within a BUS CLEAR DELAY, 88@@ nsec) deassert and passively 
release all bus signals except RST itself. 


The RESET condition stays on for at least one RESET HOLD TIME, 25 
usec. During the RESET condition, no bus signal except RST can 
be assumed valid. . 


Regardless of the prior bus phase, the bus resets to a BUS FREE 
phase following a RESET condition. 


By setting jumpers A-B on the ACB-55808 jumper header (J6), the 
user can select either a hard reset mode or a soft reset mode. 


When the jumper is installed, a hard reset mode is established. 
When in hard reset mode, a RESET condition will force the ACB- 
5588 to clear all uncompleted commands, to release all reserva- 
tions including dual port reservations, and to return all other 
modes, including mode select, set limits, and diagnostic states 
to their power on default conditions. The next time a drive is 
selected from the Initiator, the drive and all its mode select 
parameters will be re-initialized. 


When the jumper is not installed at position A-B, a soft reset 
mode is established. After clearing the SCSI bus information and 
waiting until. the Reset Condition has ended, the ACB-5508 will 
attempt to complete any uncompleted commands which were fully 
identified. All SCSI device reservations and operating modes are 
preserved. The ANSI X3T9.2 SCSI specification defines the condi- 
tions under which commands are considered completely identified 
and completed. 


4.1.4 PHASE SEQUENCING 


Phases are used on the bus in a prescribed sequence. In all 
systems, the RESET condition can interrupt any phase and is 
always followed by the BUS FREE phase. (Any other phase can also 
be followed by the BUS FREE phase.) 


The normal progression is from BUS FREE to ARBITRATION, from 
ARBITRATION to SELECTION or RESELECTION and from SELECTION or 
RESELECTION to one or more of the INFORMATION TRANSFER phases 
(COMMAND, DATA, STATUS or MESSAGE). 
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There are few architectural restrictions on the sequencing 
between INFORMATION TRANSFER phases although the ACB-558@0 does 
have a clearly defined sequence of transfers which it manages. 
4.1.5 TIMING 


Timing requirements are defined in the ANSI X3T9.2 SCSI 
Specification. Unless otherwise indicated, the delay time 
measurements for each device are calculated from signal 
conditions existing at the device port. Delays in the bus cable 
need not be considered for these measurements. 


fe) ARBITRATION DELAY: 2.2 microseconds 
The minimum time that an SCSI device should wait from assert- 
ing BSY for arbitration until the data bus can be examined to 
see if arbitration has been won. There is no maximum time. 


re) BUS CLEAR DELAY: 8808 nanoseconds (maximum) 


The maximum time allowed for a device to stop driving all bus 
Signals after the release of BSY when going to BUS FREE. 


fe) BUS FREE DELAY: 888 nanoseconds 
The minimum time allowed to an SCSI device from detection of 
the BUS FREE phase to its assertion of BSY and its I.D.. 
during arbitration. 
fe) BUS SETTLE DELAY 489 nanoseconds (minimum) 
fe) DESKEW DELAY: 45 nanoseconds (minimum) 
fe) RESET HOLD TIME: 25 microseconds (minimum) 
The minimum time during which RST is asserted. No maximum. 
o- SELECT TIMEOUT DELAY: 258 milliseconds 
The delay allowed for a BSY response from a TARGET before 
time out during SELECTION, 
4.1.6 ELECTRICAL INTERFACE 
All signals are low true and use open collector drivers 
terminated with 228 ohms to +5 volts (nominal) and 338 ohms to 


ground at each end of the cable. 


Each signal driven by the controller has the following output 
characterists: 


True (Signal Assertion) = 8.8 to @.4 VDC @ 48 mA (max/) 
False (Signal Non-Assertion) = 2.5 to 5.25 VDC. 
Adaptec controllers use a 7438 open collector driver to meet this 
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specification. 


Each signal from the host to the controller must have the 
following characteristics: 


True (Signal Assertion) = 8.8 to 8.8 VDC @ .4mA (max.) 
False (Signal Non-Assertion) = 2.8 to 5.25 VDC. 


A 74LS14 receiver with hysteresis meets this specification. 


Figure 4-1 shows an example of proper bus termination. 


CONTROLLER TYPICAL HOST ADAPTOR 





741514 





74LS240 







20 FEET 
(6 METERS) 
MAXIMUM 


Figure 4-1. Host Adapter Bus Termination 


Solel CONNECTION DIAGRAM 


A 5@-pin latching connector is provided at position J8 for 
connecting to the SCSI bus. The SCSI single-ended non-shielded 
connection is used. All signals are asserted at the low level. 
All odd pins are grounded. A maximum cable length of 2@ feet (6 
meters) is allowed. Figure 4-2 shows the SCSI connection pins. 
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Ground 1] 2] - Data Bit @ (DBO) 
4 " 1 
6 v 2 
8 " 3 
18 " 4 
12 " 5 
14 " 6 
16] - Data Bit 7 (DB7) 
18{ - Data Bit P (DBP) 
20 Ground 


23. 122 Ground 
25 |24 Ground 


27 |26 No connection 
28 Ground 
30 Ground 
32] - Attention 
34 Ground 
36} - Busy 
38} - Acknowledge 
49{ - Reset 
42] - Message 
44| - Select 
46] - Control/Data 
48; - Request 
49 {|58] - Input/Output 


Figure 4-2. SCSI Bus Pin Assignments 


4.2 MESSAGE SPECIFICATION 


The message system allows communication between an Initiator and 
an ACB-559@0 for purposes of physical path management. This 
section defines the messages supported by the ACB-5509. 


4.2.1 MESSAGE SYSTEM 


The ACB-5598 supports a considerable number of messages to 
perform such special functions as disconnect/reconnect and 
command linking. Certain Initiators, including the Adaptec host 
adapters, fully support those messages, but certain others do 
not. The Initiator indicates that it can support more than the 
COMMAND COMPLETE message by creating the ATTENTION condition 
prior to the bus state of SEL asserted and BSY deasserted in the 
SELECTION phase. 


If the ACB-550@ sees this ATTENTION condition, it will request a 
message byte from Initiator by executing a MESSAGE OUT 
information transfer. The outcoming IDENTIFY message indicates 
the drive to be selected and also indicates whether the 
disconnect/reconnect functions are supported by the Initiator. 
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The first message out may also be a BUS DEVICE RESET message. 


4.2.2 SCSI MESSAGE DESCRIPTIONS 


Table 4-2 shows the messages supported by the ACB-550@. 


Table 4-2. Message Codes Supported by the ACB-554@ 


HEX 
CODE DESCRIPTION DIRECTION 
GG Command Complete In 
G2 Save Data Pointer In 
G3 Restore Pointers In 
04 Disconnect In 
G5 Initiator Detected Error Out 
86 Abort Out 
87 Message Reject In Out 
G8 No Operation Out 
OA Linked Command Complete In 
6B Linked Command Complete w/Flag In 
gC Bus Device Reset Out 
88 to FF Identify In Out 


4.2.2.1 SINGLE BYTE MESSAGES 


Command Complete (99,,) 


This message is sent by the ACB-55908 to indicate to the Initiator 
that the execution of a command or series of linked commands has 
terminated and that valid status has been sent to the Initiator. 
After sending this message, the ACB-5508@ drops BSY and goes to 
the BUS FREE phase. 


Save Data Pointer (62 43) 


This message is sent by the ACB-55988 to direct the Initiator to 
Save a copy of the present active command execution state, 
including data address pointers and other information, for the 
currently connected disk drive. See the SCSI specification for a 
definition of pointers. 
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Restore Pointers (83,4) 


This code is sent from the ACB-55@8@ to direct the Initiator to 
restore the most recently saved pointers for the particular 
identified LUN to the active state. Pointers to the COMMAND, 
DATA, and STATUS locations for the LUN will be restored to the 
active pointers. COMMAND and STATUS pointers will be restored to 
their value at the beginning of the present command. The DATA 
pointer shall be restored to the value at the beginning of the 
command or at the value saved when the last SAVE DATA POINTER 
message was executed. 


Disconnect (844) 


This message is sent by the ACB-5588 to inform an Initiator that 
the present physical path is going to be broken (the Target will 
disconnect by releasing BSY), but that a later reconnect will be 
required in order to complete the current operation. By not 
sending this message or the COMMAND COMPLETE message before going 
to BUS FREE phase (other than as a result of reset), the Target 
indicates that an error condition has occurred on the current 
command. This message does not save the DATA POINTER. 


Initiator Detected Error (85,5) 


This message is from the Initiator to inform the ACB-5509 that an 
Initiator-detected retryable error has occurred since the last 
time the state of the DATA POINTER was saved. Commonly, this is 
for a data parity error. The ACB-5589 will post error status 
with an error code of 2D. 


Abort (86) 

The message is sent from the Initiator to direct the ACB-55998 to: 

o Clear any operation for the specified LUN from the selecting 
Initiator. Only an operation for the selecting Initiator is 
affected. If no logical unit has been selected by the 
IDENTIFY message, then only the operation in process on the 

bus will be cleared by the Target. 
o Cause the bus to go to the BUS FREE phase. 
No status or ending message shall be sent for the operation. It 


is not an error to issue this message to an LUN that is not 
currently performing an operation for the Initiator. 
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Message Reject (67;;) 


This code is sent from the Initiator or ACB-5508 if the message 
received was inappropriate or not implemented. The Initiator 
will assert the ATTN signal prior to its release of ACK for the 
REQ/ACK handshake of the message that will be rejected. When the 
ACB-550@ sends this message, it will change to MESSAGE IN phase 
and send this MESSAGE prior to requesting additional message 
bytes. 


No Operation (88 ,,) 


This message is sent from an Initiator in response to the ACB- 
55@0's request for a message when the Initiator does not 
currently have any other valid message to send. 


Linked Command Complete (@A}) 


This message is sent from the ACB-5588 to an Initiator to indi- 
cate that the execution of a linked command has been completed 
and that status has been sent. The Initiator is then allowed to 
set up the pointers for the initial state for the next linked 
command. 


Linked Command Complete with Flag (9B,,) 


This message is sent from the ACB-5508 to an Initiator to indi- 
cate that the execution of a linked command (with the FLAG set) 
has completed and that status has been sent. The Initiator is 
then allowed to set up the pointers for the initial state of the 
next linked command. Typically the FLAG would cause an interrupt 
in the Initiator. 


Bus Device Reset (@Cy) 


This message can be sent from an Initiator to direct the ACB-55@8 
to reset all current I/O operations on that BUS DEVICE. This 
message forces the ACB-550@ to an initial state with no opera- 
tions pending for any Initiator. Upon recognizing this message, 
the ACB-55088 goes to the BUS FREE phase. 


Identify (80, to FFy) 


This code is sent by either the Initiator or ACB-5588 to estab- 
lish the physical path connection between the Initiator and ACB- 
5508 for a particular disk device (or Logical Unit). 

Bit-7 is always set to identify this message. 


Bit-6 is set by the Initiator to indicate it is capable of accom- 
modating disconnection and reconnection. 
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Bits-5, 4, 3, and 2 are reserved and must be zero. 


Bits-l, and @ specify a logical unit number (disk drive address) 
address in the ACB-55@@. 


4.3 FUNCTIONAL DESCRIPTION OF SCSI COMMANDS 
By defining a fixed block structure using a simple, logical 
address scheme, the I/O interface can support device indepen- 
dence. The same code can be used to support both the ACB-5509 SMD 
Disk Controller and the ACB-5508 ST5@6 Disk Controller. In 
addition, by including the logical block address as a component 
of the command structure, implicit operations (such as SEEK and 
Retry) can be performed by the basic READ and WRITE commands. 


This interface, despite its simplicity, is capable of providing 
the high level of performance required in a multi-host/multi-task 
environment. Functional examples of SCSI command and data inter- 
actions are detailed below. 


4.3.1 SINGLE COMMAND EXAMPLE | 
A typical operation for the ACB-5500 is a READ of disk data. 


The Initiator has an active state and a set of stored states 
(representing active disconnected devices). The Initiator sets 
up the active state for the operation requested by the host 
system, arbitrates for the SCSI bus, and selects the ACB-5590@. 
The ACB-558@8 then assumes control of the operation. 


The ACB-559890 checks to see if ATTN is present, indicating that 
the Initiator is hoping to send an Identify message. The ACB- 
5508 obtains the Identify message and uses it to determine which 
logical unit (SMD drive) is being addressed. The ACB-558@8 then 
obtains the command descriptor block, 6 or 18 bytes of command 
information, and determines that a Read of certain logical blocks 
is desired by the Initiator. The ACB-5508 performs all the disk 
control and data transfer operations necessary to transmit the 
logical blocks to the Initiator. All seeks, retries, defect 
skipping, and error correction are performed to recover the 
logical blocks as quickly as possible and with no management from 
the Initiator. 


After the read data has been transferred to the Initiator, the 
ACB-55898 presents ending status and a Command Complete message to 
inform the Initiator that the operation was completed success- 
fully. The bus is then freed for further operations. 
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4.3.2 DISCONNECT/RECONNECT EXAMPLE 


In the above READ example, the drive may require a time-consuming 
physical seek to reach the requested data. In order to improve 
system throughput, the ACB-5588 disconnects from the Initiator, 
freeing the SCSI bus to allow other Initiator requests to be sent 
to other controllers or other devices on the same controller 
- @uring the time that would otherwise be unusable. 


A typical disconnection is performed after the READ Command has 
been transferred and before data is transferred. The ACB-55098 
indicates that the Initiator must store its active state informa- 
tion by sending a Store Pointers message, then sends a Disconnect 
message to indicate that the SCSI bus will be freed up, but that 
the operation will continue later. | 


When the physical motions of the device are complete, the ACB- 
5588 reselects the Initiator and passes an Identify message to 
it. The Identify message provides the necessary information for 
the Initiator to re-activate the stored state information. The 
read operation then continues as previously described. 


4.3.3 LINKED COMMAND EXAMPLE 


The Link function defines a relationship between commands which, 
when combined with the RELATIVE ADDRESS BIT, allows previous 
operations to modify subsequent commands. Linked operation makes 
high performance I1/0-functions possible by providing a relative 
addressing capability and allowing multiple command execution 
without invoking the host software and without requiring a new 
SELECTION phase. | 


As one example of a linked operation, the Initiator may want to 
restrict any Read operations to a certain set of tracks. This 
may be done by linking a SET LIMITS command to a READ command. 
After normal execution of the SET LIMITS command, the ACB-559@0 
presents a LINKED COMMAND COMPLETE message instead of a COMMAND 
COMPLETE message. The LINKED COMMAND COMPLETE indicates to the 
Initiator that it must now set up for the next command, a READ. 
The ACB-558@ requests the Command Descriptor Block, interprets 
the READ, and continues a normal READ command, but limited to the 
set of logical blocks specified by the SET LIMITS command. 


The linked command structure can similarly be used by the SEARCH 
EQUAL command, followed by a disk READ of the data found. 


4.3.4 COMMAND QUEUING EXAMPLE 


In a multi-host environment, (say, file server) the data are 
shared among hosts. When one host is using drive A,access from 
the other hosts to the same drive will get busy status since the 
drive can only do one task at one time. The other hosts must 
continue to poll the status of drive A until the busy goes away. 
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The polling has three disadvantages: 


A. Cause SCSI bus busy 
B. Require host overhead 
C. The response time is delayed by the host polling interval 


This delay could be as long as several hundred milli-seconds. 
The ACB-5588 and ACB-55898 will queue the requests from the other 
hosts and disconnect from the SCSI bus. AS soon as the first 
host request is done, one of the queued requests is performed by 
reconnecting to the host. This function will dramatically 
increase the performance of a multi-host environment. 


4.4 COMMAND STRUCTURE 


4.4.1 COMMAND DESCRIPTOR BLOCK (CDB) 


An I/O request to a device is made by passing a Command 
Description Block (CDB) to the Controller. The first byte of the 
CDB is the command group and operation code. The remaining bytes 
specify the Logical Unit Number (LUN), starting block address, 
control byte, and the number of blocks to transfer. Commands are 
categorized into two formats supported in Adaptec controllers: 


o Group @: 6-Byte commands 
o Group 1: 18-Byte commands 


Figures 4-3 and 4-4 show typical Group @ and Group 1 command 
descriptor block formats. 


BIT 

BYTE }#£«;°;G7 86 G5 G4 G3 G2 G1 oe) 
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OE ceil aaa ee 
eid ye ge Va 
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Figure 4-3. Group @ Commands (6-Byte Commands) 
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Figure 4-4. Group 1 Commands (1@9-Byte Extended Block Address) 


4.4.2 GROUP CODE 


The group code can be @ to 7 indicating the SCSI command group. 
The ACB-55@@ uses only 8 and 1 to indicate Group @ (6 byte) and 
Group 1 (19 byte) Commands. 


4.4.3 OPERATION CODE 


The operation code indicates to the controller the command to be 
executed. The operation code allows for 32 commands (9@ HEX to 
lF HEX). 


4.4.4 LOGICAL UNIT NUMBER 


Logical Unit Numbers identify up to 8 devices attached to a 
controller. The ACB-5588 accepts Logical Unit Numbers from @ to 
3, addressing 4 SMD disk devices per controller. The Logical 
Unit Number is only examined and used by the ACB-5508 if the 
IDENTIFY message was not provided. 
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4.4.5 COMMAND SPECIFIC BITS 


Byte Ol, bits 91-94 eRaerey options which apne upon the par- 
ticular command. 


4.4.6 RELATIVE ADDRESS BIT 


The RELATIVE ADDRESS BIT (Bit @ of Byte @1) of the Group 1 
commands is set to indicate that the block address portion of the 
CDB is a two's complement displacement. This displacement is to 
be added to the Block Address last accessed on the unit to form 
the Block Address for the present command. This feature is only 
available when linking commands. The feature requires that a 
previous command in the linked group have accessed a block of 
data on the device. 


4.4.7 LOGICAL BLOCK ADDRESS 





Group @ commands contain 21-bit starting block addresses while 
Group 1 supports 32-bit block addressing. 


4.4.8 NUMBER OF BLOCKS 


A variable number of blocks may be transferred under a single 
command. Group 8 commands may transfer up to 256 blocks, while 
Group 1 commands may transfer up to 65,535 blocks. A zero value 
for a Group 8 command implies a 256 block transfer. A zero value 
for a Group 1 command implies a zero length transfer. 


4.4.9 CONTROL BYTE 


The control byte is the last byte in a Class @@8 or Class @1 
command. The command byte is defined as follows: 


Bits 7-2 Reserved; must be zero 


Bit l FLAG--This bit indicates that an interrupt is 
requested for this command in a group of linked 
commands. This bit may only be set for LINKED com- 
mands. oo 


Bit @ LINK--This bit indicates the existence of a LINKED. 


command which will be automatically executed upon 
successful completion of the current command. 
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- 4.5 COMPLETION STATUS BYTE 


Status is always sent at the end of a command or set of linked 
commands. Intermediate status is sent at the completion of a 
linked command. Any abnormal condition encountered during com- 
mand execution causes command termination and ending status. 


BIT 
BYTE Q7 G6 85 G4 83 G2 G1 GO 


Check 


Reserv 


B) esa 




















Figure 4-5. Completion Status Byte 
Bits 8, 5, 6 & 7: Zero for ACB-55@0@. 


Bit l: Check condition. Sense is available. See REQUEST SENSE 
command, section 6.3. 


Bit 2: Condition met. Set when any SEARCH is satisfied. 


Bit 3: Busy. Device is busy or reserved. Busy status will be 
sent whenever the ACB-5598 is unable to accept a command from a 
Host. This condition occurs when a Host that does not allow 
reconnection requests an operation from a reserved or busy 
device. It also occurs if a dual port device is reserved to the 
other controller. 


Bit 4: Reservation Conflict. When set with bit 3, indicates 


drive access or reservation request in conflict with an existing 
reservation. 
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5.9 ST566 INTERFACE DESCRIPTION 


Dak INTRODUCTION 


The ST5@06 Interface is an industry standard for connecting 5 1/4" 
Winchester disk drives to disk controllers. The ST5@6 interface 
is based on an interface developed by Seagate Technology for the 
ST5@6 and ST412 disk drives. This interface has since been 
implemented in a majority of 5 1/4" disk drives. The ST5066 
interface, as implemented by the ACB-558@0, is characterized by 5 
Mb/s data and an MFM encoding scheme. 


DEEZ INTERFACE SIGNALS 


The ST5@6 interface consists of a control cable and one or more 
data cables. The control cable is multi-dropped from the ACB- 
5588 to all attached disk drives. The last drive on the daisy 
chain must have resistive terminators installed to terminate the 
control cables. The data cables are radially connected between 
the ACB-55@@ and a single drive. To use the ACB-55098 with four 
drives, the maximum supported, one control cable and four data 
cables are required. Figure 5-1 shows the ACB-5568 cabled for 
this configuration. 
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TERMINATOR 





Figure 5-1. ACB-55980 Cabling 
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The daisy-chained control cable connects to the ACB-559@ through 
a 34-pin edge card connector Jl. The suggested mating connector 
is 3M P/N 3402-000. The pin assignment for Jl is shown in Table 
5-1. 


Table 5-1. J1 Connector Pin Assignment 


GND RTN SIGNAL 
PIN PIN SIGNAL NAME 


Direction In 








—_ 
—_ 


—_ —_ —> 


2 
2 
2 
2 
2 


NO 


2 
10 
12 
14 
16 
18 

0 

2 

4 

6 

8 
30 
32 
34 


(6%) 
(s¥) 
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The radial data cables connect to the ACB-550@ through 2@-pin 
header connectors J2, J3, J4, and J5. Drive 9 must be connected 
to J2 as drives 1 and 3 must be connected to. J3 to...J35 
respectively. The suggested mating connector is 3M P/N 3421- 


90900. The pin assignment for J2, 33, J4, and J5 is shown in 
Table 5-2. 


Table 5-2. J2, J3, 34, and J5 Connector Pin Assignment 


oe A SIGNAL 
PIN SIGNAL NAME 


Drive Selected 
7 Reserved 
Reserved 
MFM Write Data 
MFM Write Data 















MFM Read Data 
MFM Read Data 


The control signals used by the ST 5086 interface are transferred 
using the driver/receiver circuit shown in Figure 5-l. The 
control signals are specified as: 

True = @.@ VDC to @.4 VDC 


False = 2.5 VDC to 5.25 VDC. 
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2202) 
74LS14 





Figure 5-2. ST5@6 Control Signal Driver/Receiver Circuit 


The MFM read and write data is transferred as differential 
Signals using RS-422 drivers/receivers.,. Figure 5-3 shows the 
driver/receiver circuit used by the ACB-5590@. 


CONTROLLER 100 DISK 


MC3487 1002 


75175 


Figure 5-3. MFM Data Driver/Receiver Circuit 
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Dated OPTIONAL LINES FOR HARD-SECTORED AND REMOVABLE DRIVES 


Co aa a a 


Hard-sectored and removable drives require some additional 
Signals across the drive interface. These are supported by the 
ACB-5598 when indicated by the proper board jumper condiguration 
and MODE SELECT command (15,5). 


The hard sector drive interface requires a signal line to 
transmit sector pulses to the ACB-55@@ for proper data transfers, 
This line is assigned to pin 16 of connectors J2 through J5. 
Installing jumpers E-F and/or G-H will cause the ACB-5580 to use 
this signal. 


Removable drives provide two additional lines for monitoring the 
status of the removable cartridge. These are Change Cartridge, 
signaling the drive to spin down, and Cartridge Changed, 
Signaling the controller the cartridge has been changed. These 
lines are assigned to pin 2 of Jl and pin 9 of J2 through J5 
respectively. The ACB-5508 reports a changed cartridge with the 
next disk access through a Cartridge Changed (28) error code. 


Write project is also used by removable drives to signal a 
protected cartridge. This line is assigned to pin 5 of 
connectors J2 through J5. The ACB-55@09 reports a write protect 
violation through a Write Protect Violation (27,,) error code. 


A more detailed description of these signals can be obtained from 
the disk driver OEM manual. 


5.3 DISK FORMAT 
The ACB-5589 disk format is based on the standard ST 506 format 
and is compatible with the ACB-4998 controller. Table 5-3 


details the ACB-559@0 disk format for soft-sectored drives. Table 
5-4 details the disk format for hard-sectored drives. 
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Table 5-3. ACB-5580 Soft-Sectored Disk Format 





ONE SECTOR 
(Repeated) 
ae aoe 
DATA FIELD| BCC} GAP 3 TOTAL 
BYTES 
# OF BYTES PER 
SECTOR 


256 Byte Sector 
1:1 Interleave 
32 Sectors/Trk 


. >2:1 Inter leave 
33 Sectors/Trk 


512 Byte Sector 
L:1 Interleave 
17 Sectors/Trk 


>2:1 Interleave 
18 Sectors/Trk 


1824 Byte Sector 
21:1 Interleave 
9 Sectors/Trk 


1824 Byte Sector 
22:1 Interleave 
9 Sectors/Trk 
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Table 5-4. ACB-550@0 Hard-Sectored Disk Format 


INDEX 






GAP 1 | SYNC im AM | CYL | HD | SEC | FLAG} ECC }| GAP 2 | AM {AM} DATA FIELD] ECC 


pepe tet tt ee 
256 
Be 










Note: The Cylinder Head and Sector bytes contain a single 
logical block address. 
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6.G COMMAND DESCRIPTIONS 


The following section describes the command set of the ACB-55090. 
Adaptec has followed the ANSI X3T9.2 SCSI Specification where 
Deviations occur only to Support special Adaptec 
functions or to clarify certain commands with a very large number 


possible. 


of possible implementations. 


possible conditions and the exception Sense Error Code. 


Command 
Code 


00 (HEX) 
1 
83 
B4 
88 
BA 
OB 
OF 
1g 
11 
12 
13 
14 
15 
16 


17 
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Table 6-1. Command Code Summary 


Command Name 
Test Unit Ready 
Rezero Unit 
Request Sense 
Format Unit 
Read 

Write 

Seek 

Translate 

Set Threshold 
Read/Reset Usage Counter 
Inquiry 

Write Buffer 
Read Buffer 
Mode Select 
Reserve 


Release 


Data/Parameter 


Sense Info In 
Defect List Out 
Data In 


Data Out 


Info In 
Info Out 
Info In 
Info In 
Data Out 
Data In 


Info Out 


Each command contains a list of 


Source* 


Command 
Code 


1A (HEX) 
1B 

1c 

1D 

25 

28 

2A 

2E 

2F 

31 


33 


iy 
oui 
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Table 6-1. Command Code Summary 


(Continued) 

Command Name Data/Parameter 
Mode Sense | Info In 
Start/Stop Unit --- 
Receive Diagnostic Info In 
Send Diagnostic Info Out 
Read Capacity Info In 
Read (Extended) Data In 
Write (Extended) Data Out 
Write and Verify Data Out 
Verify --- 
Search Data Equal Data Out 


Set Limits --- 


SCSI Standard Command 
Adaptec Special Function 
SCSI Standard Command with Adaptec Subset. 


Source* 


SA 


S 


SA 


SA 


SA 


SA 


SA 


6.1 TEST UNIT READY (064) 


BIT 

BYTE 87 06 85 G4 83 G2 G1 404) 

Tae ee ae a a ae ae 
i pee ae ero a aaa 
7 a ae ih 
OF aan ee a ee 
ah 
a ae 


Figure 6-1. TEST UNIT READY Command 


This command returns zero status if the requested unit is powered 
on and ready. If the drive is busy or reserved, appropriate 
status bits are set. If the drive is not operational, a check 
condition will be set in the status byte. In that case, Sense 
information will be preserved if a REQUEST SENSE command follows 
immediately. 


Valid Errors: 


Error | Error Code 
Drive Not Ready O44 
Write Fault 03,; 
Selection Failure O54 
Bad Argument 24, 
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6.2 REZERO UNIT (@1y) 


BIT 
BYTE @7 G6 G5 G4 G3 G2 G1 Oe 
er teaerag (seruee angen ger anc eer Ga uy" cae ae a 

On) g g g g G 4) 4) 1 
Ol Logical Unit Number Reserved (@) 

g2 Reserved (8) 

G3 Reserved (8) 

G4 Reserved (8) 

85 Reserved (8) | Flag | Link 


Figure 6-2. REZERO UNIT Command 
This command sets the selected drive to track zero and then sends 
completion status. This may reset certain drive hardware 
failures. 


Valid Errors: 


Error Error Code 
No Seek Complete G2 
Drive Not Ready G4 
No Track @ 06 
Selection Failure 85S 
Bad Argument 24 
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6.3 REQUEST SENSE (03);) 


BIT 
BYTE 87 G6 85 G4 83 G2 G1 ) 
clo. ol ae ee ee 
1 | Logical Unit Number] Reserved (8) 
a | ©. Reseryds (a) - 
G3 - : eserves (a) ; - 
af © | Allocation Length sts—~—S 
oe {| © Reserved (8) ~—*«Y' Filag ‘| Link 


Figure 6-3. REQUEST SENSE Command 


This command returns unit sense. 


The sense data will be valid for the CHECK status condition sent 
to the Host and will be saved by the controller until requested. 
Sense data will be cleared on receiving a subsequent command to 
the LUN related to the check condition from the Host that 
received the check condition. Other hosts will receive BUSY 
status to commands for a LUN with non-zero sense to report. 
Therefore, CHECK status should always be followed by a SENSE 
Command. . 


The ACB-550@ returns 4 bytes of sense information in response to 
this command. The number of bytes should equal @4, however, 
values of 08, 81, 82, and @3 will default to 04. 


The REQUEST SENSE command is the most important mechanism for 
informing the host of abnormal states discovered by the ACB-556@@. 


BIT 
BYTE 87 G6 05 G4 G3 G2 G1 8@ 
gg |Adrval| Error Class Error Code (See Tables) 
a | Henerved (6) | (HEB) Uogical. Block Address 
a2 |. Bog ical Boek Address ee 
83 oe ee hogical Bieer Address OO ~ (LSB) 


Figure 6-4. REQUEST SENSE Data 
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Valid Errors: 


Error . Error Code 
Bad argument 24y 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fy 
SCSI HA/Initiator Detected Error 2Dy 


The AdrVal (Address Valid) bit indicates that the Information 
Bytes contain a valid logical block address for which the error 
condition was recorded. 


The error class indicates the general type of error detected. 
Class @ errors are related to drive state, including ready, seek 
complete, write fault and similar errors. Class 1 errors are 
related to data recovery problems. Class 2 errors are related to 
invalid requests from the host system. Class 7 is the class 
defining SCSI extended sense information. 


The error code defines precisely the failure that was detected. 
These codes are described in Table 6-2. 


The logical block address is either 21 or 32 bits long depending 
on the sense format option selected. It contains the address of 
the logical block for which the failure was detected. If the 
AdrVal bit is off, the logical block address is not meaningful. 
A few sense error codes store other information in the logical 
block address without turning on the AdrVal bit. 


Table 6-2. Class @@ Error Codes In Sense Byte (Drive Errors) 
CODE ERROR MEANING 
0) NO SENSE No error occurred or 
error cleared before 
REQUEST SENSE command. 


G1 NO INDEX/SECTOR No index or sector signal 
found during rd, wr, or format 


G2 NO SEEK COMPLETE Seek complete signal missing 


03 WRITE FAULT Drive detected failure 


which disallows writes 
G4 DRIVE NOT READY Drive not ready 
05 SELECTION FAILURE Incorrect Select 


indication returned. 
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Table 6-3. Class 91 Error Codes In Sense Byte (Target Errors) 


CODE ERROR MEANING 
10 ID CRC ERROR ID field could not be 
recovered by retry 
11 UNCORRECTABLE Data field error could 
DATA ERROR not be recovered by retry 
or correction 
12 ID ADDRESS MARK Missing ID address mark 
NOT FOUND 
14 RECORD NOT FOUND Logical block ID not on 


accessed tracks, but no ID 
CRC error 


15 SEEK ERROR Could not seek to track 
with correct ID 


16-17 NOT ASSIGNED 


~—=218 DATA CHECK IN See Send Diagnostic 

NO RETRY MODE command 

19 ECC ERROR DURING See Verify command 
VERIFY 

1A NOT ASSIGNED 

1B NOT ASSIGNED 

1C UNFORMATTED OR Format failed, no valid 
BAD FORMAT ON format on drive 
DRIV See Section 6.3.1 


1D-1F NOT ASSIGNED 
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Table 6-4. 


CODE 
290 
21 


22 
23 


24 
25 


26 


27 


28 


29 


2B 


2C 


2D 


2E 


2F 
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ERROR 





ILLEGAL COMMAND 
ILLEGAL BLOCK 
ADDRESS 

NOT ASSIGNED 


VOLUME OVERFLOW 


BAD ARGUMENT 


INVALID LOGICAL 
UNIT NUMBER 


NOT ASSIGNED 
WRITE PROTECT 


CARTRIDGE 
CHANGED 


MICROCODE 
DETECTED 


SET LIMIT 
VIOLATION 


ERROR COUNT 
OVERFLOW 


SCSI 
HA/INITIATOR 
DETECTED ERROR 


SCSI BUS OUT 
PARITY. CHECK 


ADAPTER PARITY 
CHECK 


Class @2 Error Codes (System-Related Errors) 


MEANING 


Command code is invalid 
or not implemented 


Block address outside 
address space by Logical Unit 


Illegal block address 
after first block 


Reserved bit not zero 
or invalid parameter 


Logical Unit greater than 
3 addressed 


Drive has write protect 
option active 


A disk drive cartridge 
was installed since the 
last time a command was 
executed. 


Difference in drive parameter 
data and physical drive 
characteristics 


Read, Write, or Set Limit 
attempted in violation of 
previously linked Set Limit 
Command . 


Posted when error count 
exceeds specified threshold 


A message '@5'y 
(Initiator Detected Error) 
was received from the host 


A parity check was 
detected on SCSI bus out- 
bound information transfer. 


The ACB-55@@ detected an 
internal hardware check. 
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6.3.1 BAD FORMAT ON DRIVE 


The ‘1C' error code provides further information in the low order 
3 bytes of address information, even though the address valid bit 


is not set. 


Sense 


ntent 


Byte Co 
O01 


G2 


83 


Progress code 
Sectors read before failure occurred. 


Error code detected at time error was 
found and progress code set. 


The progress code indicates when the failure occurred, 


described bel 


Progress Code 
1@ 


ll 


12 


13 


14 


15 


16 


OW: 


Probable Failure 


as 


Rezero failure. Typically the drive is not 


ready. 


Index/Sector Detect and First Read. The drive 
is incorrectly cabled, unable to read, or the 
ACB-550@ has an internal failure. The drive may 


not be formatted. 


Drive Parameter Read Failure. The drive media 


has failed or drive operation is marginal. 
previous format may be incomplete. 


The 


Wrong Block Size/Invalid Data. The drive 
parameters read from the disk are not valid. 


The disk may not have been formatted by 
Adaptec controller. 


an 


Seek to Last Track Failed. The drive cannot 


seek or fails during seeks. The drive may 
formatted with the wrong number of cylinders. 


Unable to Read Last Flag Byte. The drive 


be 


is 


failing to read on inside tracks. The format 
operation may have been halted before drive 


formatting was completed. 


Failure to Read Defect Information. The drive 


is unable to read certain tracks/heads. 


For all progress codes, the error codes stored in byte 3 will 
valid, although no block address information will be available. 
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be 


6.4 FORMAT UNIT (044) 


BIT 

BYTE 7 G6 G5 G4 83 G2 G1 GO 
jer ge ag ge ge ge gg 
g1. | Logical Unit Number] Data | Cmplt] List Format Bits 
2);  « Data Pattern tt tstst~S 
93 | (MSB)  ~Interleave 
G4 : : iiterieaye ~ (LSB) 
an) ine Reserved (8) | Flag | Link 


Figure 6-5. FORMAT UNIT Command 


The ACB-55080 will write from index to index all ID and DATA 
fields with the format specified by an immediately previous MODE 
SELECT (15,4) command. If no MODE SELECT command has been exe- 
cuted, the previous format will be used. On unformatted disks or 
those whose format cannot be determined (sense byte error code 


1c,; returned following a READ), a MODE SELECT command is required 
prior to the format command. Data fields are completely written 


with 6C, unless otherwise specified in the format command. 


The ACB-55088 formats out all indicated disk defects during disk 
formatting. | 


Byte @1 is used to indicate if a list of defect locations is 
appended and whether unique fill characters are to be used. 
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Bits 8, 2, 3, and 4 indicate the presence and format of the 
defect list. The ACB-5580 only supports bytes from index format. 
Bit 1 indicates whether a unique fill character is to be written 
into the data fields during format. Table 6-5 details the format 
options provided by the FORMAT UNIT command. 


Table 6-5. Format Options 


Bit 
Data Cmplt Format Defect List Fill Byte 


4 3 2-5 98 


) 6 6 B B No defect list 6C., 
Y) 6 8 1 @ No defect list Value in Byte @2 
1 1 1 @ @ Complete defect list in 6C., 
bytes from index format 
1 1 1 1 @ Complete defect list in Value in Byte 82 


bytes from index format 


Sector interleaving may be required because performance limita- 
tions in the host. The sector interleave number is equivalent to 
the number of disk revolutions required to read or write a full 
track of data. 


The ID fields will be interleaved as specified in byte @4 of the 
CDB. The ACB-5588 controller does not require interleaving 
because of a high speed buffer control. An interleave number of 
1 results in sequential ID fields being written on the disk. Any 
interleave number between 1 and the number of sectors per track 
results in interleaved formatting. A @in this field will cause 
the default interleave factor of 1 to be used. Byte 3 must 
always be zero. The value in byte 4 must not exceed the number 
of sectors per track minus one. An error code of 24, (Bad Argu- 
ment) will be returned if either of these rules are violated. 


An example of an interleave number of 3 with 32 sectors per track 
follows: . 


P- 68 G01 62 63 04 65 66 67 68 69 16 11 12 13 14 15 16 
F- @6@ 11 22 91 12 23 62 13 24 03 14 25 94 15 26 985 27 


- 1718 19 20 21 22 23 24 25 26 27 28 29 39 31 32 
27 66 17 28 67 18 29 68 19 36 89 28 31 18 21 32 


~ 
Hou 


Physical sector count | 
Formatted logical sector locations 
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If data errors are noted by the controller while reading the 


defect list, all formatting is stopped and a Bad Argument (24y) 
is returned to the host. 


Valid Errors: 


Error | Error Code 
All Class @ Errors 88-O51, 
Unformatted or Bad Format 1Cyy 
Bad Argument | 244 
Write Protect 27, 
Cartridge Changed 284 
SCSI Initiator Detected Error . 2D, 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fy 


6.4.1 DEFECT HANDLING 


The ACB-550@ handles disk defects on a sector level. Instead of 
assigning alternate tracks, at the cost of performance and capac- 
ity, the ACB-559098 deletes only the sector which contains a disk 
defect. All subsequent logical sectors are then shifted down by 
one physical position. See Figure 6-6. 


CYLINDER 2 |[98]99|19@] > - ++ esse + Jn] 


CYLINDER 2 |98/99| D|19G] Dj1@1] + + + + [n-2| 


2 Defects 


Figure 6-6. Sector Level Defect Skipping 
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To facilitate system applications where a consistent number of 
sectors are required per cylinder and to allow reformatting of 
single cylinders when required by field grown defects, the ACB- 
5500 allows a specified number of sectors per cylinder to be 
spared during formatting. The number of Spare sectors allocated 
to each cylinder is variable from @ to N-l (N = # of 
sectors/track) and is specified in the FORMAT UNIT format infor- 
Mation. For every spare sector allocated, one less sector will 
be available on each cylinder. To assure defects within a 
cylinder do not cause sectors to be shifted into the next 
cylinders, a number of spare sectors greater than the expected 
number of defects per cylinder should be chosen. Figure 6-7 
shows the effect of sector sparing. 


CYLINDER 2 |98/99|19aj° * + + + * [194]195] S| Ss | s | 


No Defects; 3 Spare Sectors 


CYLINDER 2 [98/99] D |1@@|D|101]° * +> > = [194]195] S$ | 





2 Defects; 3 Spare Sectors 
Figure 6-7. Sector Sparing within Cylinders 


If the number of defects within a cylinder should exceed the 
number of spare sectors, the additional sectors will overflow 
into the next cylinder. Assuming the next cylinder has enough 
Spare sectors to account for defects within the cylinder and the 
overflow sectors, no other cylinders will be affected. This 
cylinder will now contain all of its assigned sectors plus the 
overflow. Figure 6-8 describes the effects of overflow sectors. 
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CYLINDER 2 | 98] D | D [1G] D [1la@1lj° * + |192]193]194| 


4 Defects; 3 Spares 


CYLINDER 3 [195/196] D [197] °° ° * * * * [292/293] s | 


1 Defect; 3 Spares; 1 Overflow 


Notes In this example cylinder 2 now contains 97 sectors 
and Cylinder 3 contains 99, the remaining cylinders 
on the disk contain 98. 


Figure 6-8. Sector Sparing and Overflow Sectors 

In the case of formatting out a grown defect(s) within a cylinder 
with no available spares, all subsequent cylinders must be 
reformatted until an adequate number of spares are available to 
account for all overflowing sectors. 

6.4.2 FORMAT UNIT DATA 

Two format options exist, one using the standard SCSI defect list 
for formatting an entire disk drive, the other using an Adaptec 


defect list for reformatting a single cylinder. 


Figures 6-9 and 6-19 detail the data required for entire drive 
and cylinder level formatting. 
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BYTE 87 6 5 G4 G3 G2 G1 8B 
0 ral te cake Gpeieadey 
a | Number of Spare Sectors —~™S 
a2 | Lengthof 
a3 | Defect List in Bytes (8N)) tw 
04 | (MSB)) Cylinder Number of Defect #1 ‘| 
a5 | | Cylinder Number of Defect #1 ie 
at a Cylinder Number of Defect #1 = 
Cn (ee Head Number of Defect #1” 
98 | (MSB) Bytes From Index CS 
0 | Bytes From index —_— 
a ea notes Peon tndey BO 
cP a Bytes From Index” (LSB) 
sN—4 a aa a alan eee! 
to Nth Defect | 
BNF3 mmm rrr 


Figure 6-9. Format Unit Data Block (Drive Formatting) 


Byte @@8 indicates the formatting option for the drive. 986 
indicates the entire unit is to be formatted; 981 indicates only 
‘the specified cylinder is to be formatted. 


Byte @1 indicates the number of spare sectors to be allocated per 
cylinder. The number of spare sectors allocated must be the same 
for every cylinder for single cylinder formatting. A @@ in this 
byte will result in no spare sectors. 


If no spare sectors are allocated, the defective sector pushdown 
algorithm limits the number of defects to 128. If bytes 2 and 3 
specify more than 128 8-byte descriptors, a Bad Argument (2414) 
error will be posted. If one or more spare sectors are 
allocated, a number of sectors, up the total number of spares, 
may be marked as defective. The number of spare sectors allo- 
cated on a cylinder must be less than the number of sectors on a 
single track of the cylinder. 
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Bytes 82 and @3 indicate the number of following date. bytes 
containing defect descriptors and/or format information. 


For entire unit formatting, bytes 94 through 11 indicate the 
physical location of the first defect descriptor (defect location 
in terms of cylinder, head and bytes from index). The defect 
descriptors must be listed in ascending order starting from 
cylinder 8, head @. 


For single cylinder formatting, bytes 94 through 11 indicate the 
cylinder to be formatted and the starting sector number of the 
cylinder. The starting sector number can be determined using the 
READ MAXIMUM CAPACITY (25,,) command on the previous cylinder. 


Note: The user must caution when sectors overflow from one 
cylinder to another. If incorrect starting sector number 
is used, missing sector error will be detected during 
read, write or verify commands. 
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BYTE 87 86 85 G4 93 G2 G1 OR) 
ao | anes oe forast Option (1) 
ao {| | Number of Spare Sectors s—(‘i‘~™~S 
a2 | Length of Appended  —(iti‘“—:~™S 
Cn Sn anns pata in Byte = —s 
64 | (MSB) Cylinder Number i itsti‘SC‘*” 
Ee To Be BO 
oe fe Formatted = ~~ (LSB) 
oe 0 
086 | (MSB) 
ao {| | Starting 
19 «| )))™™”™”™”~”~”:CSector Number ss—s 
ao fs: hl 
2) « First 4 
: : Defect ; 
19 | Descriptor | 


Figure 6-18. Format Unit Data Block 
(Cylinder Level Formatting) 


588504-086 6-17 


6.5 READ (084) 


BIT 
BYTE 67 G6 a5 G4 93 G2 G1 ao 
te ee ge gg 
g1 | Logical Unit Number| (MSB) Logical Block Address 
a | Logical Block Address. . =. t™” 
3 {| Rodtcal Block Address _ ~ (LSB) 
af ©. Number of Blocks —(‘sSCS~S™ 
0 | Reserved (8) ‘| Flag | Link 


Figure 6-11. READ Command 


This command transfers from the ACB-55098 the specified number of 
blocks starting at the specified logical starting block address 
of the selected ST 506 drive. 


The control unit will verify a valid seek address and proceed to 
seek to the specified starting logical block address. If discon- 
nection is allowed, the ACB-5508 will disconnect during seek 
actuator motion and will reconnect when the device is again ready 
to transfer data. When the seek is complete the controller then 
reads the data field into the buffer, checks ECC and begins first 
data transfer to the Initiator. 


Subsequent blocks of data are transferred into the buffer ina 
similar manner until the block count is decremented to Zero. 
Cylinder switching is transparent to the user. On a data ECC 
error, the block is re-read up to 5 times to establish a solid 
error syndrome. Only then is correction attempted. Correction 
is done directly into the data buffer, transparent to the host. 


Blocks containing uncorrectable data errors will be transferred 


to the host prior to an ending check status. A REQUEST sense 
will return an uncorrectable data error (11,,) error code. 
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Valid Errors: 


Error 


All Class @ Errors 

I.D. CRC Error 
Uncorrectable Data Error 
I.D. AM Not Found 

Data AM Not Found 

Record Not Found 

Seek Error 

Data Check (No Retry Mode) 
Bad Format 


Illegal Block Address 


Volume Overflow 

Bad Argument 
Cartridge Changed 
Media Error 

Set Limit Violation _ 


SCSI HA Detected Error 


SCSI Bus Out Parity Check 


Adapter Parity Check 


Error Code 


Ce ed 


11* 
12*H 
13*,, 
14¥*y 
LS* 
18*y 
1c 
21y 


234, 


2445 


28, 


294 


2B, 


2Dy 


2Ey 


2Fy 


*Address will be valid in sense data 


This set of errors is collectively referred to as Read Operation 


Errors. 
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6.6 WRITE (@A,,) 


BIT | | | 
BYTE 87 G6 g5 g4 93 G2 «G1 G@ 
eaeete ppoeass |e ar pene eg | eae a ase eae eae a [rears 
Ont) g y) g ) 1 g 1 G 
G1 Logical Unit Number (MSB) pogical Block Address 
G2 uOgECe “Blosk Naa vees 
G3 togieal Block hadbese (LSB) 
G4 Number of Blocks 
G5 Reserved | (G) | Flag | Link 


Figure 6-12. WRITE Command 


This command transfers to the selected ST 586 drive on the ACB- 
5598 the required number of blocks starting at the specified 
logical block address. The controller seeks to the specified 
logical starting block. If disconnection is allowed, the ACB-550@ 
will disconnct during seek actuator motion and will reconnect 
when the device is again ready to transfer data. When the seek 
is complete, the controller transfers the first block into its 
buffer and writes the buffered data and its associated ECC into 
the first logical sector. 


Subsequent blocks of data are transferred until the block count 


is decremented to zero. Cylinder, head switching, and defect 
skipping are transparent to the user. 
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Valid Errors: 


Error Error Code 

All Class 9 Errors 98-G5*,, 
I.D. CRC Error 1O*y 
I.D. AM Not Found 12*,, 
Record Not Found 14*y 
Seek Error | 15*5 
Bad Format 1CH 
Illegal Block Address 215 
Volume Overflow 234 
Bad Argument 24, 
Write Protected 274 
Cartridge Changed 28,, 
Microcode Detected Error 294 
Set Limit Violation 2B,, 
SCSI HA Detected Error 2Dy 
SCSI Bus Out Parity Check | 2E,, 
Adapter Parity Check 2Fy 


*Address will be valid in sense data. 


This set of errors is collectively referred to as Write Operation 
Errors. 
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BIT 
BYTE 7 06 5 04 G3 G2 G1 OK) 
ele eg oe ee ge a a 
g1 | Logical Unit Number| (MSB) Logical Block Address 
G2 EE onl Boek Aadvess re 
G3 3 = Pegical Block Aaaress oO ~ (LSB) 
of Reserved (8) ssts—S 
Cr ra aes Reserved (8)  ~~—~—~*Y': Flag ‘| Link 


Figure 6-13. SEEK Command 


This command causes the selected drive to seek to the specified 
starting address. If a head seek is required, the ACB-5588 will 
disconnect from the SCSI bus and reconnect upon seek completion. 
The ACB-5580 returns completion status immediately after the seek 
pulses are issued and head motion starts. Any command received 
for a unit with a seek in progress will immediately complete with 
a command completion status of busy (bit 3 set). 


The drive is moved to the expected track position but no ID 
field verification is attempted. | 


The ACB-5588 uses an implied seek on READ, WRITE and SEARCH 
commands eliminating the need for SEEK commands before each 
operation. 


Valid Errors: 


Error Error Code 
No Seek Complete G2y 
Drive Not Ready 04, 
Select Failure . 05H 
Bad Format 1c, 
Illegal Block Address 21y 
Bad Argument 24, 
Invalid Logic Number | 254 
Initiator Detected Error 2Dy, 
SCSI Bus Out Parity Error 2EH 
Adapter Parity Check 2F i 
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6.8 TRANSLATE (@F,) 


BIT 
BYTE 07 G6 G5 04 83 G2 G1 Om) 
Saas (ec ger a ecg 

oY) ) 4) g 4) 1 1 l 1 
G1 Logical Unit Number} (MSB) Gogical Block Address 
G2 Logical Block Address 
83 Logical Block Address (LSB) 
g4 Reserved (@) 
05 Reserved (0) | Flag | Link 


Figure 6-14. TRANSLATE Command 


This command performs a logical address to physical address 
translation and returns the physical location of the requested 
block address in a cylinder, head, bytes from index format. This 
data can be used to build a defect list for the FORMAT command. 


To translate logical blocks, the ACB-55@08 physically seeks the 
designated block and reads its physical location. If there is a 
data error in the ID field, an error status will be returned. It 
is then necessary to TRANSLATE the blocks before and after the 
targeted block and use the track format shown in Tables 5-3 and 
5-4 to determine the location of the target block. The presence 
of formatted (skipped) defects will require a more complicated 
algorythm for determination of the error location. 


Eight bytes are returned in the format of defect descriptors 
required by the FORMAT UNIT command, Figure 6-15. 
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BYTE G7 06 a5 Q4 G3 G2 01 OG 

ig Vee ee ee ee oe apa 
i ge Ne ae eee 
Pe cael ea a a 
i ae ee ee 
07 = “Bytes From Tadex ce (LSB) 


Figure 6-15. TRANSLATE Data 


Valid Errors: 


Errors Error Code 
All Class @ Errors — 88-854 
I.D. CRC Error 
I.D. AM Not Found l2y 
Record Not Found 14, 
Seek Error 154 
Bad Format 1c, 
Illegal Block Address . 214 
Bad Argument 24, 
Cartridge Changed . 284 
SCSI HA/Initiator Detected Error 2Dy 
SCSI Bus Out Parity Error 2EH 
Adapter Parity Check 2Fy 
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6.9 SET THRESHOLD (19;;) 


BIT 
BYTE 07 06 G5 04 G3 G2 01 8B 
oe eel ieeteeel remsereel -otel oer eervaaerel hese 
BO ) G g 1 4) 4) 4) ) 
G1 Logical Unit Number | Reserved (@) 
G2 Reserved (@) 
G3 Reserved (0) 
B4 Bytes to be Transferred (@1) 
a5 Reserved (08) | Flag | Link 


Figure 6-16. SET THRESHOLD Command 


The ACB-5588 optionally provides an error logging capability for 
those errors that are normally retried without any notification 
to the host system. The ACB-5588 counts blocks transferred, seek 
errors, and retried and corrected data errors. The error logging 
mode and the frequency of error presentation is established by 
the SET THRESHOLD command, while the actual error information is 
presented by the READ/RESET USAGE COUNTERS command. The default 
state is error logging, but not reported. Power on reset estab- 
lishes the default state. 


One byte of parameter data will be transferred. 


4) Threshold Value 


‘A threshold value of @ specifies that no error reporting will 
take place. A value between 1 and 255 will request that error 
reporting takes place. When the number of errors of any single 
type exceeds the threshold, the command that finds that error is 
completed normally. All subsequent commands will be terminated 
immediately with Check Condition. Sense status will indicate 
2Cue Error Count Overflow. When a READ/RESET USAGE COUNTER 
command is executed, the usage and error counters are off loaded 
and normal operation continues. The same threshold value remains 
in effect. 
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Valid Errors: 


Error Error Code 
Drive Not Ready O44 
Bad Argument 24, 
Cartridge Changed 284 
Initiator Detected Error 2Dy 
SCSI Bus Out Parity Error 2Ey 
Adapter Parity Check | 2Fy 


6.10 READ/RESET USAGE COUNTER (lly) 


BIT 
BYTE 07 86 a5 G4 G3 G2 Gl GO 
a |[anonae|anoman | nonnnn |-nann= |anomen | asanne | aan 
0) g i" g 1 g 4] @ 8 
dl Logical Unit Number | Reserved (@) 
G2 Reserved (0) 
03 Reserved (@) 
o4 Bytes Allocated (09) 
@5 Reserved (0) _ | Flag | Link 


Figure 6-17. READ/RESET USAGE COUNTER Command 


The READ/RESET USAGE COUNTERS command recovers the information 
stored by the ACB-559@0 for the particular disk device. The 
information is valuable to observe the statistical performance of 
the device and to point to devices which may need service before 
their performance degrades system operation. 


All seeks and sectors read are counted in three byte counters. 
Seek errors, correctable data errors, and uncorrectable data 
errors are counted in one byte counters. 


When one of the error counters exceeds the threshold, all 
subsequent commands for that device will terminate einen 
with Check Condition status and an error code of 2Cye Error 
Counter Overflow. This will continue until See cut on. of the 
READ/RESET USAGE COUNTER command, which recovers the 9 bytes of 
counter information and resets the counters. 
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BYTE G7 G6 85 G4 G3 G2 G1 G@ 

oo | (mss) irae ees ree ais aaa eae 
i ee 
gf eeceemeadcoune = St 
a3 | (wa) SSS*S*C~S eek age Count. 
reece, 
gf eee ygage Gomme ae) 
of dococractsbie Uataicueck-come. 
a coprectavle Datacicck come. 
ih a oo 0 aeeeanaan 


Figure 6-18. READ/RESET USAGE COUNTER Parameters 


The Sectors Read Count is a complete count of all logical blocks 
read to any host from the specified drive. This provides usage 
information against which error counts can be calibrated. 


The Seek Usage Count is a complete count of all occurrences of an 
initial seek by the drive. Cylinder switching is not counted. 


The Uncorrectable Data Check Count counts all occurrences of an 
uncorrectable data check on the specified device. Each Uncor- 
rectable data check was also posted as a 11, error code. 


The Correctable Data Check Count counts all occurrences of the 
successful recovery of a logical block that was unsuccessfully 
read at first. This information is available only through error 
logging, since these errors are recovered without notifying the 
host unless a diagnostic mode has been invoked. 


The Seek Check Count counts all occurrences of a seek error 
whether or not recovery was successful. This information is 
available only from error logging, since seek errors are normally 
recovered without notifying the host. 
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Valid Errors: 


Error | | Error Code 
Drive Not Ready 44 
Bad Argument 244, 
Cartridge Changed 284 
Initiator Detected Error 2Du 
SCSI Bus Out Parity Error 2Ey 
Adapter Parity Check 2Fy 


6.11 INQUIRY (12,,) 








BIT 
BYTE 07 G6 65 G4 83 G2 G1 oO 
o foe foe Pe Pe ea 
a1 | Logical Unit Number | ~— Reserved (8) —™” 
Pa Reserved (8) 
2 | )©=©)—™”~“<s~*‘< RM (DO s—Ss. 
a4 | fe te Allocation Length tttiststs—s—~S 


g5 | | Reserved (6) | | Flag | Link 


Figure 6-19. INQUIRY Command 


The INQUIRY command requests parameters describing the ACB-559@ 
and attached devices. . 


The Allocation Length specifies the number of bytes that the 
Initiator has allocated for returning Inquiry Data. The ACB-5590@ 
will return the Allocation Length number of bytes or 4 bytes, 
whichever is less. Zero is a valid Allocation Length and 
indicates no data may be transferred. 


BIT . 
BYTE G7 06 85 G4 83 G2 G1 GG 
a | I-----" lag Toilact acces Device typy) 
alee, Rested ee 
ff ge 
3 fo es AGels | a aka a aaa 


Figure 6-28. INQUIRY Parameters 
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Byte @8 of the parameter list is zero, indicating that the 
attached devices are direct access disk devices with a read and 
write capability. The RMB bit of byte @1 indicates whether the 
attached LUN is a fixed or removable drive. This bit equalling 
l indicates a removable drive. Removable media drive can be 
identified by the MODE SENSE command. Byte 92 is @1, indicating 
that the ACB-55080 meets the SCSI specifications, version 14. The 
only significant exception is the definition of the Format 
Cylinder Option and optional fill character. Byte 83 is @@, 
indicating that no other bytes are defined. 


Valid Errors: 


Error Error Code 
Bad Format 1Cy 
Bad Argument 24), 
Cartridge Changed 28H 
Initiator Detected Error 2D 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fy 


6.12 WRITE DATA BUFFER (134) 


BIT 
BYTE 87 86 a5 G4 83 G2 G1 8G 
ae Teac eta us (aa et ae ck 
Bd Y) g g 1 g Qg 1 1 
G1 Logical Unit Number Reserved (@) 
G2 Reserved (@) 
G3 Reserved (@) 
G4 Reserved (@) 
G5 Reserved (@) | Flag | Link 


Figure 6-21. WRITE DATA BUFFER Command 


This command serves buffer RAM diagnostic purposes. The control- 
ler will fill the buffer with 4K bytes of data from the host. 
There is no guarantee that this data will not be overwritten by 
other operations initiated by other Initiators. 
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6.13 


BYTE 


8B 


G1 


G2 


G3 


G4 
85 


Valid Errors: 


Error Error Code 
Drive Not Ready O44 
Bad Argument 245 
SCSI HA/Initiator Detected Error 2Dy 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fy 
READ DATA BUFFER (14,,) 
BIT 
07 06 05 G4 93 G2 G1 OO 
eit Fea ae ag me ae ae ane lo 
g ) g 1 G g @ 
Logical Unit Number Reserved (@) 
Reserved (0) 
Reserved (@) 
Reserved (@) 
Reserved (@) | Flag | Link 


Figure 6-22. READ DATA BUFFER Command 


READ DATA BUFFER will pass the host 2K of data from the buffer. 


It is 


intended for RAM diagnostic purposes. 


Although data 


remains in the buffer after normal data operations, the ordering 
of the data found there may vary. 


Valid Errors: 


Error Error Code 


Drive Not Ready 

Bad Argument 

SCSI HA/Initiator Detecter Error 
SCSI Bus Out Parity Check 
Adapter parity Check 
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6.14 MODE SELECT (15,) 


BIT , 

BYTE 07 G6 05 G4 G3 82 G1 Om) 
ae ee a a ee 
1 | Logical Unit Number] Reserved” 
oa | Rewetved (8) - 

G3 : ; “Baeapued (0) - 
af Number of Bytes s—~tS 
ci  . .* s Reserved (6) ‘| Flag | Link 


Figure 6-23. MODE SELECT Command 


This command is used by the ACB-55@@8 to specify formatting param- 
eters and should always preceed the FORMAT UNIT command. When a 
Blown Format error (1C,) is detected due to the controller being 
unable to read the drive parameter information from a drive 
already formatted, the user may use this command to inform the 
controller about the drive information. Once initialized, most 
data on the drive may be recoverable. The information can then 
be recovered and the drive reformatted. Writes to the drive will 
not be permitted. 


Byte 94 of the command specifies the number of information bytes 
to be passed with the command. The ACB-55@@ will post an Invalid 
Argument error unless this equals 22 (16,;) or 24 (18,,) bytes. 


The Mode Select parameters are architecturally divided by the 
SCSI document into a header (bytes @0-93), a block descriptor 
(bytes 94-@B), and vendor unique parameters. The following 
parameters are required by the ACB-5509. 


Note: After issuing a Mode Select Command, only the Read Command 
is executable before a new Format Command is executed. 


580504-09 6-31 


BYTE 07 06 G5 4 93 G2 1 On) 
0 | eg es ae a ae 
61 ~  Regerved (0) 7; 

G2 : : Reseived (0) - - 

03 | Length of Extent Descriptor List = 08 
oa | )|)—t”~é“‘é™SO.OCORSity COdet—“<i‘SCS 
06 | Reserved (8) | 
96 = ; Reservaa (a) ; 

07 - Réderved (3) - - 

08 7 Reseevad (3) ; 

s9 | (MSB)0tt—~—~S Block Size sts—~—S 
OA a - - Block Size - - - 

OB Bisek Size : ~ (LSB) 


Figure 6-24. Extent Descriptor List 


Byte @4, the Density Code, uses the default value of 8@H, since 
the density parameters are not available to the operating system. 


Bytes 89 through @B specify the data block size. The ACB-5596 
supports block sizes of 256 bytes, 512 bytes, and 1924 bytes. 
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BYTE 7 6 5 4 3 2 1 4) 
i po eae ai 
oa Se aa aaa 
ge ee et ee Sieeeccee  eee 
rae eieaaeciaoa Sg ln 
ise °° Lea 
he eee ee 
os | uss) o.oo. 
o7 | Wrice Precompensation se | LSB 
eo en ec. 
oo ee 


Figure 6-25. Drive Parameter List for 
Soft-Sectored, Fixed Drives 


The List Format Code must be set to 91 for soft-sectored drives 
and @2 for hard-sectored or removable drives. 


The Cylinder Count is the numbe of data cylinders on the drive. 
The ACB-5508 does not use alternate cylinders for defect 
management, so these may be included as data cylinders. The 
minimum number of cylinders is one, the maximum is 2048. 


The Data Head Count is the number of usable data surfaces. The 
minimum is 1, the maximum is 16. A drive with 9 or more heads 
will use the Reduced Write Current line as the high-order head 
select. . 


The Reduced Write Current cylinder is the cylinder number beyond 
which the controller will assert the Reduced Write Current line. 
The minimum value is @. Note that the reduced write current line 
is used as a fourth head select line for drives with more than 8 
heads. 


The Write Precompensation cylinder is the cylinder beyond which 


the controller will compensate for inner track bit shift. The 
minimum value is @. | 
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Note: For drives which do not require Reduced Write Current 
and/or Write Precompensation, the user should set these 
cylinder values at the number of data cylinders plus l. 


The Landing Zone position is used with the START/STOP command to 
indicate the direction and number of cylinders from the last, or 
first, cylinders to the desired skipping or stopped position. 
The most significant bit indicates the direction. A @ indicates 
the landing zone is beyond the maximum cylinder; a 1 indicates it 
is before track 9. The other 7 bits indicate the number of 
cylinders in the desired direction the head will stop. 


The Step Pulse Rate specifies the timing of seek steps. The 
three options are: 


98 = Non-Buffered Seek (3.9 ms/step) 
G1 = Buffered Seek (28 us/step) 
@2 = Buffered Seek (12 us/step) 
BIT 
BYTE 7 6 5 4 3 2 1 d 
o | Wet eiee eocgee Code a 
g. | MsB |” Cylinder Count = sti‘; ;O*~*~™” 
in Sanne Cylinder Count stst—<—s 
ee ee Data Head Count i ttst—~S 
a4 | MBB |” Reduced Write Current 
an Reduced Write Current = | LSB 
a6 | MSB |! Write Precompensation 
87 ef ee Writes Breconsensat ion a i 
rn Landing Zone Position ————~C~S 
69 | | $tep Pulse Rate 
oa | Drive Type Code t—“‘éSOSCSC~™S 
Ot es Sector Count ststs—~S 


Figure 6-26. Drive Parameter List for 
Hard-Sectored, Removable Drives 


The Drive Parameter List for Hard-Sectored or removable drives 


must begin with a List Format Code of @2 and contains two 
additional bytes. This parameter List must be sent if the E-F or 
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G-H jumpers are installed. 


The Drive Type Code indicates the characteristics of the drive, 
defined as: 


Bit @-l1 = 8 —- Must be @ 
Bit 2 = @ = Soft-sectored 
= ] - Hard-sectored 
Bit 3 = 8 - Removable Media Drive 
= 1 ~ Fixed Media Drive 
Bit 4-7 = @ — Must be @ 


The Sector Count equals the number of sectors ona track. Note 
that for hard-sectored drives this must equal the number of 
sectors set by the drive manufacturer. 


6.15 RESERVE (16;;) 





BIT 

BYTE 7 6 5 4 3 2 1 O 

o | «|e | «| a|e| a1 | a | 6 
g1 |fogical Unit wumber| Reserved (@) ‘(extent 
a2 | Reservation fdentigication 
0 | se) petent tist Length SSSOS™S~S~™ 
as | 7 Extent ist fengen tua) 
of Reserved (8) ~~~*&YSag | tink 


Figure 6-27. RESERVE Command 


The Cylinder Count is the number of data cylinders on the drive. 
The ACB-5500 does not use alternate cylinders for defect 
“Management, so these may be included as data cylinders. The 
minimum number of cylinders is one; the maximum is 4994. 


The Data Head Count is the number of usable data surfaces. The 
minimum is 1; maximum is 16. A drive with 9 or more heads will 
use the Reduced Write Current line as the high order head select. 


The Reduced Write Current cylinder is the cylinder number beyond 
which the controller will assert the Reduced Write Current line. 
The minimum value is @. Note that the reduced write current line 
is used as a fourth select line for drives with more than 8 
heads. 


The Write Precompensation cylinder is the cylinder beyond which 


the controller will compensate for inner track bit shift. The 
minimum value is @. 3 
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Note: For drives which do not require Reduced Write Current 
and/or Write Precompensation, the user should set these 
cylinder values to the number of data cylinders plus l. 


The Landing Zone position is used with the START/STOP command to 
indicate the direction and number of cylinders from the last, or 
first, cylinders to the desired shipping or stopped position. 
The most significant bit indicates the direction. AO indicates 
the landing zone is beyond the maximum cylinder, as 1 indicates 
it is before track 8. The other 7 bits indicate the number of 
cylinders in the desired direction the head will stop. 


The Step Pulse Rate specifies the timing of seek steps. The 
three options are: 


98 = Non-Buffered Seek (3.8 ms/step) 
91 = Buffered Seek (28 us/step) 
@2 = Buffered Seek (12 us/Sstep). 


The Drive Parameter List for hard-sectored or removable drives 
must begin with a List Format Code of @2 and contains two 
additional bytes. This parameter list must be sent if the E-F or 
G-H jumpers are installed (indicating hard-sectored drives). 


The Drive Type Code indicates the characteristics of the drive, 
defined as: | | 


Bits @-l = @ Must be @ 
Bit 2 = Q Soft-sectored 
aan Hard-sectored . 
Bit 3 = @ Removable media drive 
= ] Fixed Media Drive 
Bits 4-7 = @ Must be @. 


This command is used to reserve logical units or extents within 
units for the use of an Initiator. 


The Reservation function is used to prohibit certain kinds of 
access from some Initiators so that the reserving Initiator can 
complete multi-step transactions without interference. Extra 
drives are also implicitly reserved to the active initiator 
during an active chain of linked commands. An Initiator may only 
have one reservation per logical unit. 


Reserve Unit: 


If the Extent bit (Bit 8 of Byte 81) is zero, and no extent 
within the unit is currently reserved by another Initiator, then 
this command shall cause the unit to be reserved for exclusive 
use of the Initiator until the reservation is released by a 
RELEASE UNIT command issued by the same Initiator or by a BUS 
DEVICE RESET message from any Initiator or a "Hard" RESET condi- 
tion. It is permissible for an Initiator to reserve a logical 
unit that is currently reserved for that Initiator. The Reserva- 
tion Identification (Byte 92) and the Extent List Length (Bytes 
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83 through @4) are ignored. If the unit or any extent within the 
unit is previously reserved, then the unit shall respond by a 
RESERVATION CONFLICT Status. 


If any other Initiator then subsequently attempts to perform a 
READ or WRITE operation on the reserved unit, that command shall 
be rejected with RESERVATION CONFLICT Status. If a REQUEST 


SENSE command is executed, a No Sense error code will be 
presented. 


The Reservation Identification (Byte 82) provides a means for an 
Initiator to identify each Extent Reservation. This allows an 
Initiator in a multi-tasking environment to have multiple 
reservations outstanding. The Reservation Identification is used 


in the RELEASE command to specify which reservation is to be 
released. 


Extent Reservation Within Units: 


Extents within a unit may be reserved, each with a separate 
Reservation Type by setting the Extent bit to l. If the 
reservation cannot be granted because of conflicts with a 
previous reservation, a RESERVATION CONFLICT status indication is 
posted. Reservations are only active when all extents are free 
from conflict with currently active reservations. 


If the extent bit is one, then: 


(1) The Extent List is checked for number of extents in the 
reservation request. The ACB-5588 supports only one extent. 
If the Extent List contains more than one extent, then the 
command shall be rejected with CHECK CONDITION Status and an 
ILLEGAL BLOCK REQUEST (21) error. 


(2) The Extent List will be checked for valid extent block 
addresses. If any address is invalid for this unit, then 
the command is rejected with the CHECK CONDITION Status and 
a Sense Key of ILLEGAL BLOCK REQUEST (21,,). 


(3) If there already is an active unit reservation for the unit, 
the command shall be rejected with CHECK CONDITION Status 
and a Sense Key of ILLEGAL REQUEST. 


(4) If the requested reservation does not conflict with any 
active reservation, then the extent specified is reserved 
until release by a RELEASE command from this Initiator or by 
a BUS DEVICE RESET message from any Initiator or a "Hard" 
RESET condition. 
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BYTE 7 6 5 4 3 2 1 an) 

gg  ebergaa | eel nar easete ayes 
a fo Number of Blocks (NSB) 
i Woe cele 
ax [~~ ~~ "77" "Number of Blocks (3B) 
ao fo Logical Block Address (NSB) 
gee ete 
ao | bagical Slcckaadcess: == SS 
a} Logical Block Address (LSB) -— 


— we ow oe ow om ate ee on ew cep com ee om we oe oe ee ee ow eee ce we re ee es ee ee ee wee es ee ee oe ee ee ee oe oe 


Figure 6-28. Extent Descriptor Format 


The size of the Extent List is defined by the Extent List Length 
parameter in the CDB. The ACB-5500 requires the length to be 
either 8 or 9. The Extent Descriptor defines an extent beginning 
at the specified Logical Block Address (Bytes 94 through 97) for 
the specified Number of Blocks (Bytes 91 through @3). If the 
Number of Blocks is zero, the extent begins at the specified 
Logical Block Address and continue through the last Logical Block 
Address on the unit. 


The Reservation Type field (Bits 1 through @ of Byte 9G) deter- 
mines the type of reservation to be effected for each extent. 
Four types of reservations are possible as follows: 


Code Reservation Type 
19 Read Exclusive 
G1 Write Exclusive 
ll Exclusive Access 
0) Read Shared. 


While Read Exclusive is active, no other Initiator shall be 
permitted READ access to the indicated extent. This reservation 
shall not inhibit WRITE accesses from any Initiator or conflict 
with a Write Exclusive reservation; however, Read Exclusive, 
Exclusive Access, and Read Shared reservations which overlap this 
extent shall conflict with this reservation. 
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While Write Exclusive is active, no other Initiator shall be 
permitted WRITE access to the extent. This reservation shall not 
inhibit READ accesses from an Initiator or conflict with a Read 
Exclusive reservation from any Initiator. This reservation 
shall conflict with Write Exclusive, Exclusive Access, and Read 
Shared reservations which overlap this extent. 


While Exclusive Access is active, no other Initiator shall be 
permitted any access to the indicated extent. All Reservation 
Types which overlap this extent shall conflict with this reserva- 
tion. 


While Read Shared is active, no WRITE accesses shall be permitted 
by any Initiator to the indicated extent. This reservation shall 
not inhibit READ accesses from any Initiator or conflict with a 
Read Shared reservation. Read Exclusive, Write Exclusive, and 
Exclusive Access reservations which overlap with this extent 
shall conflict with this reservation. 


If the RELATIVE ADDRESS bit (Bit 2 of Byte 098) is 1, the Logical 
Block Address shall be treated as a two's complement displace- 
ment. This displacement shall be added to the Block Address last 
accessed on the unit to form the Block Address for this extent. 
This feature is only available when linking commands and requires 
that a previous command in the linked group has accessed a block 
of data on the unit; if not, the RESERVE Command shall be 
rejected with CHECK CONDITION Status and an error code of Bad 
Argument (24,,). 


If an Initiator attempts to access (READ or WRITE) a block which 
has been reserved and that access is prohibited by the 
reservation, then the operation is not performed and terminates 
with RESERVATION CONFLICT Status. If any access conflict exists, 
none of the operation shall be performed. If any extent ina 
unit is reserved in any way, a FORMAT UNIT Command is rejected 
with RESERVATION CONFLICT Status. 


Note that RESERVE commands, whether for a unit or for an extent, 
are not queued. Host software is responsible for queuing reserve 
functions, since careful management of host software is required 
to detect and circumvent potential deadlocks. In multi-host 
systems, deadlock prevention may require an auxiliary communica- 
tion path or very restrictive programming conventions. 


Host software is responsible for monitoring and clearing 
reservations generated by attached hosts that have failed with 
reservations outstanding. This may require an auxiliary communi- 
cations path. The reservations for failing hosts may be cleared 
using the BUS DEVICE RESET message. Note that non-failing hosts 
must be aware of and provide permission for execution of a BUS 
DEVICE RESET since reservations on their behalf will also be 
destroyed. | | 
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Valid Errors: 


Error Error Code 
Illegal Block Address 21y 
Bad Argument 241 
Cartridge Changed 28y 
SCSI HA/Initiator Detected Error 201, 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2F 


6.16 RELEASE (17)) 


BIT 

BYTE 7 6 5 4 3 2 1 0) 

ie ee a a ee 
a1 |"cogicat Unit wunber| Raseeved (8) [extant 
Oe I i rr 
a fae 
pr SoG 
a amen: easy Fy eg la 


Figure 6-29. RELEASE Command 


This command is used to release previously Reserved devices or 
previously reserved extents within units. 


If the Extent bit (Bit 9 of Byte 91) is zero, this command causes 
the unit to terminate any active reservation from that Initiator. 
If the Extent bit is one, this command causes any reservation 
from the requesting Initiator with a matching Reservation Identi- 
fication (Byte 82) to be terminated. Other reservations from the 
requesting Initiator shall remain in effect. It is not an error 
for an Initiator to attempt to release a reservation which is not 
currently active. 


Valid Errors: 


Error Error Code 
Bad Argument | 241 
Cartridge Changed 28), 
SCSI HA/Initiator Detected Error 2Dy 
SCSI Bus Out Parity Check 2E,; 
Adaptec Parity Check 2Fy 
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6.17 MODE SENSE (1A,,) 


BIT 

BYTE 07 06 65 g4 3 G2 Ol on) 
A Go ee og | a a ee a 
g1 | Logical Unit Number| ~~ Reserved (8) t—~™S 
a | ©. Heeerued (a) 

(83 - Roearued (B) - 

o4 | Number of Bytes —<CistiC‘itws 
26 | Reserved (8) | Flag | Link 


Figure 6-38. MODE SENSE Command 


This command is used to interrogate the ACB-550@ device parameter 
table to determine the specific characteristics of any disk drive 
currently attached. 


Byte @4 of the command specifies the number of data bytes allowed 
to be returned by the command. For soft-sectored drives, this 

list is 22 bytes (16,,) long and for hard-sectored or removable 

drives, this list is 24 bytes (18,) long. Not all of the MODE 

SELECT data needs to be requested. 


The returned information will be the four-byte Parameter List, 
the Extent Descriptor List and the Drive Parameter List (if 
requested). These lists take the exact format of the data in the 
MODE SELECT command, except that the first byte will be the 
expected data count of 'l1A'H. 


The Mode Sense command information is only available if a 
previous Mode Select command was successfully executed or if the 
automatic initialization for the drive was successful. If the 
information is not available, an error status with 1C (Bad 
Format) error code is presented. 


Valid Errors: 


Error Error Code 
Bad Argument 244 
Cartridge Changed 285, 
SCSI HA/Initiator Detected Error 2Dy 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check © 2Fy 
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6.18 START/STOP UNIT (1B,,) 


BIT 

BYTE 7 G6 g5 04 G3 G2 G1 8G 
ao | a ee Pa op gp 
1 | Logical Unit Number] Reserved (8) 
a {| néearved (B) - : 
G3 : Reserved (a) ; 
G4 - Reserved (3) : |st/stp 
a aaa: Reserved (8) | Flag | Link 


Figure 6-31. START/STOP UNIT Command — 


This command allows the host to preform power-on and power-down 
routines incorporating the ACB-550@0. 


A STOP command will cause the ACB-5598@ to step the drive heads to 
the Landing Zone Cylinder specified in the MODE SELECT command. 
The controller will not accept any further commands until a START 
command is issued. 


A START command will cause the controller to perform a power-on 
initialization. | 


Bit 66, Byte @4 is used to indicate if the command is START or 
STOP. This bit equal to 1 indicates a START command. 


Valid Errors: 


Error Error Code 
Drive Not Ready G4, 
Bad Argument 244 
Cartridge Changed 281; 
SCSI HA/Initiator Detached Error 234 
SCSI But Out Parity Check 2Ey 
Adapter Parity Check 2Fu 
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6.19 RECEIVE DIAGNOSTIC (1Cy) 


BIT 
BYTE 7 6 5 4 | 3 2 l ") 
oo [aggre bb 
1 | Logical Unit Number{ Reserved (3) 
ao | ©. eiexrves (0) BE 
93 |(MSB) tS” Data Length ttttititi‘is~™S 
G4 7 - - ” Data hengeh ; - 7 (LSB) 
an Reserved (8) —*'| ‘Flag | Link 


Figure 6-32. RECEIVE DIAGNOSTIC Command 


This command sends analysis data to the Host after completion of 


a SEND DIAGNOSTIC command. Bytes 3 and 4 designate the size of 
the available buffer (in bytes). 


RECEIVE DIAGNOSTIC is used to transfer data to the host and must 
immediately follow a SEND DIAGNOSTIC command. If a READ 
DIAGNOSTIC command does not follow a SEND DIAGNOSTIC command or 
the SEND DIAGNOSTIC command has no associated data, a Bad 
Argument (24,,) error code will be posted. 


The data length specified should be 104, or more, although, if a 
smaller buffer is provided, only that much data will be 
transferred and the command will terminate normally. 


The data buffer received as a result of a dump will be formatted 
as shown in Figure 6-34. 
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BYTE 7 6 5 4 ae: 2 1 g 
ag |cwan) | | “pats Bock ‘tength'(aiea,) 
G1 - 4 - - Waka Block Paneth ; ” - (LSB) 
a2 [(MsB) Starting Address of Dump —t—t—~S 
83 - - ” - Staebing Addvess of Bump - - - (LSB) 
ao fo Dumped Data (xx) tS 
133 - - - - “pumped Data (xxFF) - - - - 


Figure 6-33. RECEIVE DIAGNOSTIC Data 


Valid Errors: 


Error Error Code 
Bad Argument 244 
SCSI HA/Initiator Detached Error 234 
SCSI Bus Out Parity Check : 2Ey 
Adapter Parity Check 2Fy 


6.28 SEND DIAGNOSTIC (1Dy) 


BIT 
BYTE 7 6 5 4 3 2 1 4) 
Tk See ee Oe ee ae ee ae 
61 | Logical Unit Number) ~— Reserved (0) t—~™S 
a a anaes Reserved (0) - - - - - 7 
03 |(MsB)t—~™S Data Length ssts—~S 
G4 7 7 : J Data Length - - (LSB) 
2 | Reserved (8) ~=~—«*Y|: Flag ‘| Link 


Figure 6-34. SEND DIAGNOSTIC Command 


This command sends data to the Controller to specify the execu- 


tion of diagnostic functions tests for Controller and peripheral 
units. 
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Bytes 3 and 4 specify the length of the data to be sent. 


The data length specified in the command must be at least 4 bytes 
long and should be equal to the length of the data block to be 
passed over to the controller. If the length specified is longer 
than needed, the excess is ignored and not transferred. 


BIT 
BYTE 7 6 5 4 3 2 1 4) 
o | re WP Sisinouele Gpacieler 
gu eeerea ay 
a ign byte of Geact aadcesa or Gusiicien °° 
af low Bye ef rare Addicass 
of digh Byte of Patch Length 
0 [ pow Byeerceieacch Gavecy = 
06 [ epelenal @scchata 
wes [OO epeicnsipatteses 


Figure 6-35. SEND DIAGNOSTIC Parameter Format 


Byte @@ of the Parameter List specifies the particular diagnostic 
function being requested. The following options are presently 
available. 


68 -- Reinitialize Drive 

61 -- Dump Hardware Area (4000-4@FF) * 
62 -- Dump RAM (8000-8@0FF, COOO-COFF) 
63 -- Patch Hardware Area* 

64 -- Patch RAM* 

65 -- Set Read Error Handling Options 


66 -- Initiate Trace 
*Standard diagnostics do not require these functions 


The detailed format for each of these options is described below. 
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6.20.1 DIAGNOSTIC 68 -- REINITIALIZE DRIVE: 

The selected drive runs through its itialization procedure, 
rezeroing, capturing the critical drive dimension parameters, 
determining the maximum capacity, and capturing defect skipping 
parameters. The parameter list is: 


Byte Contents 
% 681 
1-5 081; 


No RECEIVE DIAGNOSTIC information is available as a result of 
this diagnostic option. 


6.29.2 DIAGNOSTIC 61 -- DUMP HARDWARE AREA 


The area specified by the dump address is transferred by the 
RECEIVE DIAGNOSTIC command immediately following this SEND DIAG- 
NOSTIC command. The parameter list is: 


Byte Contents 


Low Ordel Address of Hardware Area 
5 Length of Transfer to be Performed. 


6.20.3 DIAGNOSTIC 62 -- DUMP RAM AREA 
The area specified by the dump address is transferred by the 
RECEIVE DIAGNOSTIC command immediately following this SEND DIAG- 
NOSTIC command. The parameter list is: 


Byte Contents 


62 
oa 
8a or E@y 
Low Order Address of RAM area 
5 Length of Transfer to be Performed. 


1IwWwnNreQ 


4 


6.20.4 DIAGNOSTIC 63 -- PATCH HARDWARE AREA 


6.20.5 DIAGNOSTIC 64 -- PATCH RAM AREA 

These commands will provide special diagnostic tools for analysis 
of certain very complex system interactions. No use should be 
made of these commands without contacting an Adaptec applications 
engineer, since temporary unavailability or loss of critical data 
may occur. 
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6.20.6 DIAGNOSTIC 65 -- SET READ ERROR HANDLING OPTIONS 

The selected drive is set in the special error recovery mode 
established by the contents of byte @5. The error handling mode 
is set to the default value by a hard SCSI reset condition, a 
power on reset, and by a SEND DIAGNOSTIC command specifying the 
default error handling value. 


Byte | Contents 


654; 
OO 
09, 
On 
00, 
Error Handling Option 


U&W NF & 


The Error Handling options are specified below: 
OO Default value. 


A correctable error will be corrected and all data transfer 
will be completed. No check status will be presented. If 
the error is not correctable, the controller will transfer 
the uncorrected data and post an error code of 11, with the 
address valid bit set. The address will be the logical block 
address of the bad block. 


G1, 


If an ECC error occurs on the first read of a data field, the 
data transfer operation will be halted after transfer of the 

bad data block. A check condition will be presented. The 
error code will be 18 with the address valid bit set. The 
failing block address will be in the logical block address 
field of the sense information. 


02); 


A correctable error will be corrected and the corrected data 
transferred. The operation will then stop and present check 
status and an error code of 18, as described in option 61. An 
uncorrectable error will be handled as in option @@. 


6.20.7 DIAGNOSTIC 66 -- INITIATE TRACE 


A high-level state trace facility is provided in the ACB-55098. 
The purpose is to provide the user with a tool to analyze complex 
multi-host SCSI interactions. 
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The parameter list is: 


Byte GG -- 661 


Byte @1 -- Trace control options 
Bit 3 = 1 -=- Single device tracing 
Bit 2 = 1 -- Single buffer tracing (only 


EXXX Ram area will be used) 


Bit 1 = 1 -- SCSI status tracing 
Bit @ = 1 -- Command tracing 
Byte @2 -- Single device address 


Byte 83 -- 004 
Byte 95 -- On 


The trace control options (byte @1) allow tuning of the trace 
contents to locate the particular system interaction of interest. 


Bit 3 Single device tracing 

When set, the ACB-5500 will trace all appropriate interactions on 
behalf of the LUN specified in byte @2. The information will be 
posted in RAM locations 8860-8@0DF for the selected device. 

Bit 1 SCSI status tracing 


When set, SCSI status contents will be included in the trace of 
activities. 


Bit @ SCSI command tracing 


When set, the SCSI command will be included in the trace of 
activities. 


If Byte @l1 is @@, trace is inactive. Any activation of a trace 
function has a small unfavorable effect on performance of the 
ACB-558@. The trace is automatically inactivated by a power on 
reset process. 


Trace storage exists in RAM Locations C@6@-C@DF. To request a 
trace dump, the host needs to send the controller diagnostic 
send/receive command with the appropriate ‘dump ram' instruction. 


Each trace entry consists of 2 bytes as follows: 


Byte 7 6 5 4 3 2 1 8 
8B STAT|CMD| TRACE INFORMATION 
81 LUN ID# | HA. ID # 
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Bits 6 and 7 indicate the type of trace information provided. 


Bit 67 Bit 66 Trace 
G ) SCSI Bus Trace 
iL ) SCSI Command Trace 
) 1 SCSI Status Trace 


The SCSI Bus Trace provides information on a transaction across 
the SCSI bus. This information is contained in bits 9-5. 


Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit @ Information 


] 4] g g 4) g Host Selection 

4) ] g "1 1 4] Reconnection 

] g "] 4] 1 1 Disconnection 

4] Q g 1 g 4] Attention 
Handling 

1) Q 4) 1 if) 1 Command 
Linking 

0 4] g 1 1 4) Command End 

g 4) Q 1 1 1 SCSI Reset 

") g 1 4] 4] g Bus Device 


The SCSI Status Trace provides the completion status byte 
presented in Bits @-5. 


The SCSI Command Trace provides the Command Operation Byte (Byte 
90, of CDB) received. 


Byte 81, contains the Device and Host Adapter SCSI ID numbers. 
These are the preconfigured SCSI bus addresses. 


Trace storage is organized beginning with 2 bytes of trace 
pointer followed by the wrap-around trace buffer. The trace 
pointer, in the first two bytes returned, points to the address 
of the "tail" point of the buffer. Trace information is ordered 
chronologically from the "tail" pointer, through to the top of 
the buffer (8000,, or CO00,,) and back around to 1 minus the "tail" 
pointer address. | 
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Valid Errors: 
Error Error Code 


Bad Argument 244 
SCSI HA/Initiator Detached Error 2Dy 
SCSI Bus Out Parity Check 2Ey 
Adapter parity Check 2Fy 


6.21 READ CAPACITY (25,;) 


BIT 
BYTE 7 6 5 4 3 2 1 g 
ofa he eye Te 
1 | Logical Unit Number} + ~—s- RESERVED (0) —*‘|[ Rel Ad 
o2 | (MSBy) Logical Block Address —tS 
93 eS hogical Bide Address ne ae 
G4 nina Logieal: Bleck Adapess ee 
a5 | = —— Logical Block Address ————S~S=«S CZ SB*) 
so | 0)0™”™”~*é‘“‘é™SOCOCO”CO#C*R@Served: «(8))0000™™™O™~<—~S 
a7 | 00t—“i~—~*~—“‘<“i Reve (DU 
a Full or Partial Media Indicator 
go | “Reserved (8) ‘| Flag | Link. 


Figure 6-36. READ CAPACITY Command 


If the Partial Media Indicator (PMI) is 98, this command will 
return the address of the last block on the unit. It is not 
necessary to specify a starting block address in this command 
mode. If the PMI is @1, this command will return the address of 
the last block in the cylinder which contains the specified block 
address. 


This feature is useful for determining drive capacities and 


determining the starting block number for cylinder level 
formatting 
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Figure 6-38 shows the format of the capacity data returned. 


BIT 
BYTE 7 6 5 4 3 2 lL G 
oo | (ss)! 'Gapacity Block address | 
7. Spicy eich dea 
2 fo gisaciey Glock aadessas 
3 fo Capacity Block Address SSCL) 
os | sa) pieckcises CS 
or Sick Size SCCC*C“‘i‘i<C 
or a Bick size 
0 | Block Size ~~S*S*~S*~S*~SES@SYSCS 


Figure 6-37. READ CAPACITY Parameters 
The last block address of either the drive or cylinder is 
contained in the Capacity Block Address bytes. The block size 
for the particular format is contained in the Block Size bytes. 


Valid Errors: 


Error Error Code 

All Class @ Errors G8-G51; 
I.D. ECC Error 19, 
I.D. AM Not Found 1L2y 
Record Not Found 14, 
Seek Error 154 
Bad Argument 24 
SCSI HA/Initiator Detached Error 2Dy 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fy 
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6.22 READ (28,) 


BIT 
BYTE 7 6 5 4 3 2 1 %) 
jeg gg gg gg 
g1 |togical unit Number | Reserved (0) tst—~s 
2 [(MsB) Logical Block Address t—~—S 
G3 _ tegidal Block Radvecs” eee 
G4 BE rogicel Block Address BS 
g5 BS Eogical Block Radeess- OO (LSB) 
ao | 2=0té“‘(‘éRRGS@Ved=0)™UwUwUUUUU 
an Number of Blocks sst—<—sS 
a8 | ‘Number of Blocks s—SS 
6 | Reserved = ~ ~—~—~—*| «Flag | Link 


Figure 6-38. READ Command 
This command is an extended address command which is otherwise 
identical to the Class @@ READ (98,;) command. 


The larger Logical Block Address and Number of Blocks fields are 
provided for accessing very large devices. 


Valid Errors: 


Read Operation Errors (See Section 6.5) 
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6.23 WRITE (EXTENDED) (2Aq)) 


BIT 

BYTE 7 6 5 4 3 2 1 g 

rr ee er ee ed 
1 |Logical Unit Number | Reserved (3) st” 
02 |(msB) Logical Block Address tst—~S 
a3 | = Logical Block Address s—~—S 
G4 co fe codices Rock Kade cee. Ss 
85 — <= begicat Block Raaress = (LSB) 
oo 6«|0U0UC™~*~“‘i;‘;™*SCéRSSC“‘(‘(OOC—~—SSS 
Ti Number of Blocks tstst—<—~sS 
68 Se Ndmbek of Blocks SO 
ao {| | Reserved sss 


Figure 6-39. WRITE Command 
This command is an extended address command otherwise identical 
to the Class @8 WRITE (0A,,) command. The Logical Block Address 
and Number of Blocks fields have been expanded for larger 
devices. 
Valid Errors: 


Write Operate Errors (See Section 6.6) 
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6.24 WRITE AND VERIFY (2E,) 


BIT 
BYTE 7 6 5 4 3 2 1 g 
@ fe Oe lg eh 
1 | Logical Unit Number{ Reserved (0) 
g2 | (MSB) Logical Block Address tst—~—S 
g3 | ‘Logical Block Address — 
aa {| = ~~ wogical Block Address —tS 
a5 | = ~—s Logical Block Address =———S—=«S( LSB) 
of © | Reserved (0) sts—~—S 
an Number of Blocks sts—S 
88 ee - “MuMBee of sideRe SS 
9 fo Reserved (0) ~—*+|': Flag ‘| Link 


Figure 6-48. WRITE and VERIFY Command 


This command is similar to the traditional “read after write" 
function. It is an extended address command which operates like 

a WRITE command over the specified number of blocks and then 
verifies the data written on a block by block basis. The verify 
function transfers no data to the host and only checks the ECC to 
be correct. 


Since no data is transferred to the host during verify, 
correctable data checks will be treated in the same manner as 
uncorrectable data checks. 


Valid Error: 


Read Operation Errors 
Write Operation Errors 
ECC Error During Verify 19), 
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6.25 VERIFY (2F,) 


BIT 
BYTE 7 6 S 4 3 2 1 

ro ee ee a a 

g1 | Logical Unit Number{ Reserved (0) 
g2 | (MSB) Logical Block Address iiti—S 
G3 BO Bogical: Bleck naaress 

04 = bodies Bice dares OS 

85 a Logical Block Address  : 

Tn Reserved (0) tstst—~S 
a as: Number of Blocks s—s—~—S 
88 aes gambar of Blocks BO 

gf Reserved (8) | 


Figure 6-41. VERIFY Command 


This command is similar to the previous WRITE AND VERIFY except 
that it verifies the ECC of an already existing set of data 
blocks. It is up to the Host to provide data for rewriting and 
correcting if an ECC error is detected. 


Valid Errors: 


Read Operation Errors 
ECC Error During Verify 19y 
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6.26 SEARCH DATA EQUAL (31,) 


BIT 

BYTE 7 G6 g5 G4 3 G2 01 Ort) 
ole et Ge a 
g1 | Logical Unit Number|Invert|] | Reserved (0) 
o2 | (MSB) Logical Block Address t—~tS 
G3 : pogieat Block adaress - 

04 Logical Block Address 7 : 

@5 ; bégteal Block Sddress - (LSB) 
o | 060™™t™té“‘s™SOCOCOCOC”*#*;#RQS@rVed (@)06©™©™)™U 
ao fo Number of Blocks ssst—~S 
8 Number of Blocks : 

Tn Reserved (8) —*'| Flag | Link 


Figure 6-42. SEARCH DATA EQUAL Command 


This powerful extended address command provides for a search and 
compare on equal of any data on the disk. A starting block 
address and number of blocks to search are specified and a search 
argument is passed from the Host which includes a byte 
displacement (not supported) and the data to compare. 


This command allows the host to perform a high speed data verify. 
Unlike the VERIFY Command which only checks for ECC errors, the 
search data equal will compare a chosen data pattern against data 
contained in selected blocks "on the fly." This feature provides 
an excellent method of verifying disk integrity after format by 
searching not equal for a "6C" or other unique fill character. 


The Invert bit (Byte @l, Bit 94) inverts the sense of the search 
comparison operation. With Invert on, a SEARCH DATA EQUAL com- 
mand would succeed on data not equal. 


The link bit see to zero indicates that no command is linked to 
the SEARCH DATA EQUAL command. If the search is satisfied, the 
command is terminated with CONDITION MET status. A REQEST SENSE 
command following a successful SEARCH DATA EQUAL can be issued to 
determine the Logical Block Address at the matching record. 


500504-99 6-56 


If the link bit is one, a command is linked to the SEARCH DATA 
EQUAL command. If the search is successful, the next command is 
executed. The next command may use the Relative Address Bit, in 
which case the logical block address is a displacement from the 
block at which the search was satisfied. If a linked search is 
not satisfied, the command is terminated with a Check Condition 
status. A Request Sense can then be issued to determine the 
nature of the termination. 


When a search is satisfied, it will terminate with a Condition 
Met Status. A Request Sense Command can then be issued to deter- 
mine the block address of the matching record. 

A Request Sense following a successful Search Data command will: 


1) Set the Address Valid bit to one. 


2) Report the address of the block containing the first matching 
record in the Information Bytes. 


The Request Sense command following an unsuccessful Search Data 
command will: 


1) Report an error code of No Sense (88,5), provided no errors 
occurred. 


2) Set the Valid bit to zero. 


Figure 6-44 shows the SEARCH DATA EQUAL argument. 
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BYTE 87 G6 5 G4 93 G1 0B 
dg ee) eeeedigize 
G1 - Record Size : . ; 

G2 Reword Size - : 

G3 - Record Size - ~ (LSB) 
a4 {| (MSB) First Record Offset 
a5 : "First Record Offset : 

86 ; erst Record offset : - 

Q7 - - First Rewoxd Offset - ~ (LSB) 
gs | (MSB) | ~+~Number of Records s—<i‘i—S 
89 ; sambex of Beeards - 

1d NUMIbSE of Records ; 

11 - - Number ot ResoLae - ~ (LSB) 
12 | (SB) Search Argument Length CS 
13 Search Argument Length ; " (LSB) 
14 | (MSB) = ~— Search Field Displacement 
15 - search Field pigpiacenean. 

16 - - search Field Sisplracenucnt. ; 

17 " . Search Field Dispieccmen’. ~ (LSB) 
is | (MSB) Pattern Length 

19 - “patters banden ~ (LSB) 
2 | ©. Data Pattern titi(‘;:~™S 

M+19 . - y Data Pattern - - 

Figure 6-43. SEARCH DATA EQUAL Argument 
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A definition of the required data in the SEARCH argument is shown 


in Table 6- 


BYTES 


a4) 


G4 


88 


12 


14 


18 


28 


580594-080 


6. 


TO 


to 


to 


to 


to 


to 


to 


Table 6-6. 


G3 


07 


11 


13 


17 


19 


M+19 


SEARCH DATA EQUAL Argument 
PARAMETER 


Record Size (Bytes) 

This must equal the blocksize or zero. 
zero will be taken to mean the format 
blocksize. 


First Record Offset (Bytes) 
For the ACB-55898 this must be zero. 


Number of Records 

For ADAPTEC controllers this must be 
less than or equal to the number of 
blocks specified in the command and 
greater than zero. The search will 
terminate upon a match or when the smal- 
ler of these values is encountered. 


Search Argument length (Bytes) 

The number of bytes in the following 
search argument. Must equal the pattern 
length + 6. 


Search Field Displacement 

The displacement from the beginning of 
the record to the first byte to be 
compared. Must be zero. 


Pattern Length (M Bytes) 

The number of bytes in the following 
data pattern to be compared with a like 
size field in each record. The pattern 
length must equal the blocksize. 


Data Pattern 
The block of data to be compared. 


Valid Errors: 
Error Error Code 


All Read Operation Errors 


6.27 SET LIMITS (334) 


BIT 

BYTE 7 6 5 4 i) 2 1 ) 

jee a ee ee a a 
g1 | Logical Unit Nbr | | Reserved [Rd Inh]Wr Inh_ 
62 | (MSB) Logical Block Address t—~—S 
Ge de = 7 | Logical Block Address er 
Tn Logical Block Address t—t 
05 {| | Logical Block Address ~—(LSB) 
ao | Reserved 
a7 =| (MSB) Number of Blocks iitst—<—S~sS 
a Number of Blocks = ~=~=~—~—« (LSB) 
0 6C {tt ttst~“‘;é*~*~*~:CR@SeMS~”~*~*@YSC@L'ag@’s«S('séLGnk™ 


Figure 6-44. SET LIMITS Command 


This command defines a logical block address outside of which all 
following linked commands may not operate and can be used to 
inhibit any subsequent linked reads or writes. A second SET 
LIMITS command may not be linked to a chain of commands in which 
a SET LIMITS command has already been issued. 


Bits 8 and 1 of By te @1 define the legal operations within the 
limits of the specified addresses. Bit @ indicates WRITE 
INHIBIT, and Bit 1 indicates READ INHIBIT. 


When the Number of Blocks field (Bytes @7 to 98) is zero, the 
limits shall extend from the Logical Block Address (Bytes @2 to 
 @5) to the last block on the unit. A non-zero value should not 
extend beyond the last block on the drive or an Illegal Block 
Address (21,) error code will be post ed. 
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Valid Errors: 


Error Error Code 
Illegal Block Address 21y 
Bad Argument 241; 
SCSI HA/Initiator Detached Error 2Dy 
SCSI Bus Out Parity Check 2Ey 
Adapter Parity Check 2Fu 
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APPENDIX A 


DIAGNOSTIC MODE SELF TEST 


The ACB-5508 operating microcode contains a diagnostic routine 
that is run when the DIAG jumper is installed. The primary 
purpose of this self test is to improve the reliability, 
maintainability and serviceability of the ACB-5590. The self 
test performs operational tests on the controller's major VLSI 
devices and has the ability to read/write disk data and reports 
errors by flashing the on-board LED. 


Self test is initiated upon reset or power-on of the ACB-55909 
when the DIAG jumper is installed. The self test is repeated 
allowing for the isolation of hardware problems in a customer 
environment. 


Six possible error states can occur as a result of the self test. 
The LED signals indicating each error state are shown in Table 
A-l. 


Table A-l. Self Test Error States 


LED Flashes Error Source 

Solid Light Board/88085 Microprocessor 
1 27218 EPROM 
2 8156 Local RAM 
3 6116 Working RAM Failure 
4 AIC-918 SERDES 
5 AIC-308 Buffer Controller. 


The lack of any error states indicates successful passage through 
the controller self test. 
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